Files @ 5b1f43027662
Branch filter:

Location: kallithea/kallithea/tests/vcs/test_inmemchangesets.py - annotation

mads
scripts: drop isort --wrap-length 160 - it is broken with py3 and not really necessary

Under Python 3, isort 4.3.21 failed with
https://github.com/timothycrosley/isort/issues/741 on
kallithea/controllers/api/api.py :

Traceback (most recent call last):
File "data/env/bin/isort", line 10, in <module>
sys.exit(main())
File ".../env/lib64/python3.7/site-packages/isort/main.py", line 379, in main
for sort_attempt in attempt_iterator:
File ".../env/lib64/python3.7/site-packages/isort/main.py", line 377, in <genexpr>
attempt_iterator = (sort_imports(file_name, **arguments) for file_name in file_names)
File ".../env/lib64/python3.7/site-packages/isort/main.py", line 88, in sort_imports
result = SortImports(file_name, **arguments)
File ".../env/lib64/python3.7/site-packages/isort/isort.py", line 207, in __init__
self._add_formatted_imports()
File ".../env/lib64/python3.7/site-packages/isort/isort.py", line 606, in _add_formatted_imports
self._add_from_imports(from_modules, section, section_output, sort_ignore_case)
File ".../env/lib64/python3.7/site-packages/isort/isort.py", line 526, in _add_from_imports
import_statement = self._multi_line_reformat(import_start, from_import_section, comments)
File ".../env/lib64/python3.7/site-packages/isort/isort.py", line 552, in _multi_line_reformat
dynamic_indent, indent, line_length, comments)
File ".../env/lib64/python3.7/site-packages/isort/isort.py", line 705, in _output_grid
if len(next_statement.split(self.line_separator)[-1]) + 1 > line_length:
TypeError: '>' not supported between instances of 'int' and 'str'
e2519d2e74c2
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
0a277465fddf
d1addaf7a91e
8f30206a15b5
5c9eb37bdec4
5b1f43027662
5b1f43027662
0a277465fddf
d8f820acf417
5c9eb37bdec4
d1addaf7a91e
d8f820acf417
d1addaf7a91e
d8f820acf417
d8f820acf417
d8f820acf417
d8f820acf417
d8f820acf417
d8f820acf417
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d8f820acf417
d8f820acf417
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
620c13a373c5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
d1addaf7a91e
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
620c13a373c5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
d1addaf7a91e
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
8f30206a15b5
8f30206a15b5
45bfab30d433
45bfab30d433
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
45bfab30d433
45bfab30d433
45bfab30d433
45bfab30d433
45bfab30d433
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
620c13a373c5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
d1addaf7a91e
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
8f30206a15b5
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
1bc843007746
45bfab30d433
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
1bc843007746
d1addaf7a91e
45bfab30d433
45bfab30d433
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
e63bcce18fef
620c13a373c5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
1bc843007746
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
8f30206a15b5
620c13a373c5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
e63bcce18fef
620c13a373c5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
21f7b699d467
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
d8f820acf417
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
d1addaf7a91e
e63bcce18fef
e63bcce18fef
d1addaf7a91e
8f30206a15b5
d1addaf7a91e
d1addaf7a91e
45a281a0f36f
45a281a0f36f
45a281a0f36f
45a281a0f36f
45a281a0f36f
45a281a0f36f
# encoding: utf-8
"""
Tests so called "in memory changesets" commit API of vcs.
"""

import datetime

import pytest

from kallithea.lib.vcs.exceptions import (EmptyRepositoryError, NodeAlreadyAddedError, NodeAlreadyChangedError, NodeAlreadyExistsError, NodeAlreadyRemovedError,
                                          NodeDoesNotExistError, NodeNotChangedError)
from kallithea.lib.vcs.nodes import DirNode, FileNode
from kallithea.tests.vcs.base import _BackendTestMixin


class InMemoryChangesetTestMixin(_BackendTestMixin):

    @classmethod
    def _get_commits(cls):
        # Note: this is slightly different than the regular _get_commits methods
        # as we don't actually return any commits. The creation of commits is
        # handled in the tests themselves.
        cls.nodes = [
            FileNode('foobar', content='Foo & bar'),
            FileNode('foobar2', content='Foo & bar, doubled!'),
            FileNode('foo bar with spaces', content=''),
            FileNode('foo/bar/baz', content='Inside'),
            FileNode('foo/bar/file.bin', content='\xd0\xcf\x11\xe0\xa1\xb1\x1a\xe1\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00;\x00\x03\x00\xfe\xff\t\x00\x06\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x1a\x00\x00\x00\x00\x00\x00\x00\x00\x10\x00\x00\x18\x00\x00\x00\x01\x00\x00\x00\xfe\xff\xff\xff\x00\x00\x00\x00\x00\x00\x00\x00\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff\xff'),
        ]
        commits = []
        return commits

    def test_add(self):
        rev_count = len(self.repo.revisions)
        to_add = [FileNode(node.path, content=node.content)
            for node in self.nodes]
        for node in to_add:
            self.imc.add(node)
        message = 'Added: %s' % ', '.join((node.path for node in self.nodes))
        author = str(self.__class__)
        changeset = self.imc.commit(message=message, author=author)

        newtip = self.repo.get_changeset()
        assert changeset == newtip
        assert rev_count + 1 == len(self.repo.revisions)
        assert newtip.message == message
        assert newtip.author == author
        assert not any((
            self.imc.added,
            self.imc.changed,
            self.imc.removed
        ))
        for node in to_add:
            assert newtip.get_node(node.path).content == node.content

    def test_add_in_bulk(self):
        rev_count = len(self.repo.revisions)
        to_add = [FileNode(node.path, content=node.content)
            for node in self.nodes]
        self.imc.add(*to_add)
        message = 'Added: %s' % ', '.join((node.path for node in self.nodes))
        author = str(self.__class__)
        changeset = self.imc.commit(message=message, author=author)

        newtip = self.repo.get_changeset()
        assert changeset == newtip
        assert rev_count + 1 == len(self.repo.revisions)
        assert newtip.message == message
        assert newtip.author == author
        assert not any((
            self.imc.added,
            self.imc.changed,
            self.imc.removed
        ))
        for node in to_add:
            assert newtip.get_node(node.path).content == node.content

    def test_add_actually_adds_all_nodes_at_second_commit_too(self):
        self.imc.add(FileNode('foo/bar/image.png', content='\0'))
        self.imc.add(FileNode('foo/README.txt', content='readme!'))
        changeset = self.imc.commit('Initial', 'joe.doe@example.com')
        assert isinstance(changeset.get_node('foo'), DirNode)
        assert isinstance(changeset.get_node('foo/bar'), DirNode)
        assert changeset.get_node('foo/bar/image.png').content == b'\0'
        assert changeset.get_node('foo/README.txt').content == b'readme!'

        # commit some more files again
        to_add = [
            FileNode('foo/bar/foobaz/bar', content='foo'),
            FileNode('foo/bar/another/bar', content='foo'),
            FileNode('foo/baz.txt', content='foo'),
            FileNode('foobar/foobaz/file', content='foo'),
            FileNode('foobar/barbaz', content='foo'),
        ]
        self.imc.add(*to_add)
        changeset = self.imc.commit('Another', 'joe.doe@example.com')
        changeset.get_node('foo/bar/foobaz/bar').content == b'foo'
        changeset.get_node('foo/bar/another/bar').content == b'foo'
        changeset.get_node('foo/baz.txt').content == b'foo'
        changeset.get_node('foobar/foobaz/file').content == b'foo'
        changeset.get_node('foobar/barbaz').content == b'foo'

    def test_add_non_ascii_files(self):
        rev_count = len(self.repo.revisions)
        to_add = [
            FileNode('żółwik/zwierzątko', content='ćććć'),
            FileNode('żółwik/zwierzątko_uni', content='ćććć'),
        ]
        for node in to_add:
            self.imc.add(node)
        message = 'Added: %s' % ', '.join((node.path for node in self.nodes))
        author = str(self.__class__)
        changeset = self.imc.commit(message=message, author=author)

        newtip = self.repo.get_changeset()
        assert changeset == newtip
        assert rev_count + 1 == len(self.repo.revisions)
        assert newtip.message == message
        assert newtip.author == author
        assert not any((
            self.imc.added,
            self.imc.changed,
            self.imc.removed
        ))
        for node in to_add:
            assert newtip.get_node(node.path).content == node.content

    def test_add_raise_already_added(self):
        node = FileNode('foobar', content='baz')
        self.imc.add(node)
        with pytest.raises(NodeAlreadyAddedError):
            self.imc.add(node)

    def test_check_integrity_raise_already_exist(self):
        node = FileNode('foobar', content='baz')
        self.imc.add(node)
        self.imc.commit(message='Added foobar', author=str(self))
        self.imc.add(node)
        with pytest.raises(NodeAlreadyExistsError):
            self.imc.commit(message='new message',
                            author=str(self))

    def test_change(self):
        self.imc.add(FileNode('foo/bar/baz', content='foo'))
        self.imc.add(FileNode('foo/fbar', content='foobar'))
        tip = self.imc.commit('Initial', 'joe.doe@example.com')

        # Change node's content
        node = FileNode('foo/bar/baz', content='My **changed** content')
        self.imc.change(node)
        self.imc.commit('Changed %s' % node.path, 'joe.doe@example.com')

        newtip = self.repo.get_changeset()
        assert tip != newtip
        assert tip.raw_id != newtip.raw_id
        assert newtip.get_node('foo/bar/baz').content == b'My **changed** content'

    def test_change_non_ascii(self):
        to_add = [
            FileNode('żółwik/zwierzątko', content='ćććć'),
            FileNode('żółwik/zwierzątko_uni', content='ćććć'),
        ]
        for node in to_add:
            self.imc.add(node)

        tip = self.imc.commit('Initial', 'joe.doe@example.com')

        # Change node's content
        node = FileNode('żółwik/zwierzątko', content='My **changed** content')
        self.imc.change(node)
        self.imc.commit('Changed %s' % node.path, 'joe.doe@example.com')

        node = FileNode('żółwik/zwierzątko_uni', content='My **changed** content')
        self.imc.change(node)
        self.imc.commit('Changed %s' % node.path, 'joe.doe@example.com')

        newtip = self.repo.get_changeset()
        assert tip != newtip
        assert tip.raw_id != newtip.raw_id

        assert newtip.get_node('żółwik/zwierzątko').content == b'My **changed** content'
        assert newtip.get_node('żółwik/zwierzątko_uni').content == b'My **changed** content'

    def test_change_raise_empty_repository(self):
        node = FileNode('foobar')
        with pytest.raises(EmptyRepositoryError):
            self.imc.change(node)

    def test_check_integrity_change_raise_node_does_not_exist(self):
        node = FileNode('foobar', content='baz')
        self.imc.add(node)
        self.imc.commit(message='Added foobar', author=str(self))
        node = FileNode('not-foobar', content='')
        self.imc.change(node)
        with pytest.raises(NodeDoesNotExistError):
            self.imc.commit(message='Changed not existing node', author=str(self))

    def test_change_raise_node_already_changed(self):
        node = FileNode('foobar', content='baz')
        self.imc.add(node)
        self.imc.commit(message='Added foobar', author=str(self))
        node = FileNode('foobar', content='more baz')
        self.imc.change(node)
        with pytest.raises(NodeAlreadyChangedError):
            self.imc.change(node)

    def test_check_integrity_change_raise_node_not_changed(self):
        self.test_add()  # Performs first commit

        node = FileNode(self.nodes[0].path, content=self.nodes[0].content)
        self.imc.change(node)
        with pytest.raises(NodeNotChangedError):
            self.imc.commit(
                message='Trying to mark node as changed without touching it',
                author=str(self),
            )

    def test_change_raise_node_already_removed(self):
        node = FileNode('foobar', content='baz')
        self.imc.add(node)
        self.imc.commit(message='Added foobar', author=str(self))
        self.imc.remove(FileNode('foobar'))
        with pytest.raises(NodeAlreadyRemovedError):
            self.imc.change(node)

    def test_remove(self):
        self.test_add()  # Performs first commit

        tip = self.repo.get_changeset()
        node = self.nodes[0]
        assert node.content == tip.get_node(node.path).content
        self.imc.remove(node)
        self.imc.commit(message='Removed %s' % node.path, author=str(self))

        newtip = self.repo.get_changeset()
        assert tip != newtip
        assert tip.raw_id != newtip.raw_id
        with pytest.raises(NodeDoesNotExistError):
            newtip.get_node(node.path)

    def test_remove_last_file_from_directory(self):
        node = FileNode('omg/qwe/foo/bar', content='foobar')
        self.imc.add(node)
        self.imc.commit('added', 'joe doe')

        self.imc.remove(node)
        tip = self.imc.commit('removed', 'joe doe')
        with pytest.raises(NodeDoesNotExistError):
            tip.get_node('omg/qwe/foo/bar')

    def test_remove_raise_node_does_not_exist(self):
        self.imc.remove(self.nodes[0])
        with pytest.raises(NodeDoesNotExistError):
            self.imc.commit(
                message='Trying to remove node at empty repository',
                author=str(self),
            )

    def test_check_integrity_remove_raise_node_does_not_exist(self):
        self.test_add()  # Performs first commit

        node = FileNode('no-such-file')
        self.imc.remove(node)
        with pytest.raises(NodeDoesNotExistError):
            self.imc.commit(
                message='Trying to remove not existing node',
                author=str(self),
            )

    def test_remove_raise_node_already_removed(self):
        self.test_add() # Performs first commit

        node = FileNode(self.nodes[0].path)
        self.imc.remove(node)
        with pytest.raises(NodeAlreadyRemovedError):
            self.imc.remove(node)

    def test_remove_raise_node_already_changed(self):
        self.test_add()  # Performs first commit

        node = FileNode(self.nodes[0].path, content='Bending time')
        self.imc.change(node)
        with pytest.raises(NodeAlreadyChangedError):
            self.imc.remove(node)

    def test_reset(self):
        self.imc.add(FileNode('foo', content='bar'))
        #self.imc.change(FileNode('baz', content='new'))
        #self.imc.remove(FileNode('qwe'))
        self.imc.reset()
        assert not any((
            self.imc.added,
            self.imc.changed,
            self.imc.removed
        ))

    def test_multiple_commits(self):
        N = 3  # number of commits to perform
        last = None
        for x in range(N):
            fname = 'file%s' % str(x).rjust(5, '0')
            content = 'foobar\n' * x
            node = FileNode(fname, content=content)
            self.imc.add(node)
            commit = self.imc.commit("Commit no. %s" % (x + 1), author='vcs')
            assert last != commit
            last = commit

        # Check commit number for same repo
        assert len(self.repo.revisions) == N

        # Check commit number for recreated repo
        assert len(self.repo.revisions) == N

    def test_date_attr(self):
        node = FileNode('foobar.txt', content='Foobared!')
        self.imc.add(node)
        date = datetime.datetime(1985, 1, 30, 1, 45)
        commit = self.imc.commit("Committed at time when I was born ;-)",
            author='lb <lb@example.com>', date=date)

        assert commit.date == date


class TestGitInMemoryChangeset(InMemoryChangesetTestMixin):
    backend_alias = 'git'


class TestHgInMemoryChangeset(InMemoryChangesetTestMixin):
    backend_alias = 'hg'