view tests/test-log.py @ 216:68588c652ac6

client: handle commit messages with \0 characters Mercurial allows commit messages containing \0 characters, but hglib does not properly handle them. By using the json template, these characters are correctly escaped. Note: initial change only modifies this for the 'log' command, I'll follow-up for other commands if this is ok.
author Mathias De Mare <mathias.de_mare@nokia.com>
date Wed, 08 Mar 2023 16:22:21 +0100
parents 2d0ec6097d78
children
line wrap: on
line source

from tests import common
import hglib
from hglib.util import b

class test_log(common.basetest):
    def test_basic(self):
        self.append('a', 'a')
        rev0, node0 = self.client.commit(b('first'), addremove=True)
        self.append('a', 'a')
        rev1, node1 = self.client.commit(b('second'))

        revs = self.client.log()
        revs.reverse()

        self.assertTrue(len(revs) == 2)
        self.assertEquals(revs[1].node, node1)

        self.assertEquals(revs[0], self.client.log(b('0'))[0])
        self.assertEquals(self.client.log(), self.client.log(files=[b('a')]))

        self.assertEquals(self.client.log(), self.client.log(hidden=True))

    def test_dash_in_filename(self):
        self.append('-a', '-a')
        self.client.commit(b('first'), addremove=True)
        revs = self.client.log(files=[b('-a')])
        self.assertTrue(len(revs) == 1)
        self.assertEquals(revs[0].rev, b('0'))

    def test_empty_short_option(self):
        self.append('foobar', 'foobar')
        self.client.commit(b('first'), addremove=True)
        revs = self.client.log(keyword=b(''), files=[b('foobar')])
        self.assertTrue(len(revs) == 1)
        self.assertEquals(revs[0].rev, b('0'))

    # def test_errors(self):
    #     self.assertRaisesRegexp(CommandError, 'abort: unknown revision',
    #                             self.client.log, 'foo')
    #     self.append('a', 'a')
    #     self.client.commit('first', addremove=True)
    #     self.assertRaisesRegexp(CommandError,
    #                             'abort: unknown revision',
    #                             self.client.log, 'bar')