fune/python/mozversioncontrol/test/test_update.py
ahochheiden c50783cfa7 Bug 1750693 - Minimum changes necessary in mozversioncontrol/test to facilitate Pathlib migration r=firefox-build-system-reviewers,mhentges
The py.path allowed adding arbitrary fields to it, while a pathlib.Path
does not. To replicate the behavior with as few changes as possible, I
made a test fixture wrapper class (RepoTestFixture) to add the same
arbitrary fields to, while now containing a Pathlib path instead.

Also added a utility functions to make the running of tests a
bit cleaner ('execute_next_step')

Differential Revision: https://phabricator.services.mozilla.com/D136302
2022-01-31 15:26:17 +00:00

66 lines
1.3 KiB
Python

# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
from __future__ import absolute_import
from subprocess import CalledProcessError
import mozunit
import pytest
from mozversioncontrol import get_repository_object
STEPS = {
"hg": [
"""
echo "bar" >> bar
echo "baz" > foo
hg commit -m "second commit"
""",
"""
echo "foobar" > foo
""",
],
"git": [
"""
echo "bar" >> bar
echo "baz" > foo
git add *
git commit -m "second commit"
""",
"""
echo "foobar" > foo
""",
],
}
def test_update(repo):
vcs = get_repository_object(repo.dir)
rev0 = vcs.head_ref
repo.execute_next_step()
rev1 = vcs.head_ref
assert rev0 != rev1
if repo.vcs == "hg":
vcs.update(".~1")
else:
vcs.update("HEAD~1")
assert vcs.head_ref == rev0
vcs.update(rev1)
assert vcs.head_ref == rev1
# Update should fail with dirty working directory.
repo.execute_next_step()
with pytest.raises(CalledProcessError):
vcs.update(rev0)
assert vcs.head_ref == rev1
if __name__ == "__main__":
mozunit.main()