diff options
Diffstat (limited to 'tests/test_git_superproject.py')
| -rw-r--r-- | tests/test_git_superproject.py | 39 | 
1 files changed, 39 insertions, 0 deletions
| diff --git a/tests/test_git_superproject.py b/tests/test_git_superproject.py index 225e98c2..49295d83 100644 --- a/tests/test_git_superproject.py +++ b/tests/test_git_superproject.py | |||
| @@ -21,6 +21,7 @@ import tempfile | |||
| 21 | import unittest | 21 | import unittest | 
| 22 | from unittest import mock | 22 | from unittest import mock | 
| 23 | 23 | ||
| 24 | from git_command import GitCommand | ||
| 24 | import git_superproject | 25 | import git_superproject | 
| 25 | import git_trace2_event_log | 26 | import git_trace2_event_log | 
| 26 | import manifest_xml | 27 | import manifest_xml | 
| @@ -364,3 +365,41 @@ class SuperprojectTestCase(unittest.TestCase): | |||
| 364 | 'revision="52d3c9f7c107839ece2319d077de0cd922aa9d8f"/>' | 365 | 'revision="52d3c9f7c107839ece2319d077de0cd922aa9d8f"/>' | 
| 365 | '<superproject name="superproject"/>' | 366 | '<superproject name="superproject"/>' | 
| 366 | '</manifest>') | 367 | '</manifest>') | 
| 368 | |||
| 369 | def test_Fetch(self): | ||
| 370 | manifest = self.getXmlManifest(""" | ||
| 371 | <manifest> | ||
| 372 | <remote name="default-remote" fetch="http://localhost" /> | ||
| 373 | <default remote="default-remote" revision="refs/heads/main" /> | ||
| 374 | <superproject name="superproject"/> | ||
| 375 | " /></manifest> | ||
| 376 | """) | ||
| 377 | self.maxDiff = None | ||
| 378 | self._superproject = git_superproject.Superproject( | ||
| 379 | manifest, name='superproject', | ||
| 380 | remote=manifest.remotes.get('default-remote').ToRemoteSpec('superproject'), | ||
| 381 | revision='refs/heads/main') | ||
| 382 | os.mkdir(self._superproject._superproject_path) | ||
| 383 | os.mkdir(self._superproject._work_git) | ||
| 384 | with mock.patch.object(self._superproject, '_Init', return_value=True): | ||
| 385 | with mock.patch('git_superproject.GitCommand', autospec=True) as mock_git_command: | ||
| 386 | with mock.patch('git_superproject.GitRefs.get', autospec=True) as mock_git_refs: | ||
| 387 | instance = mock_git_command.return_value | ||
| 388 | instance.Wait.return_value = 0 | ||
| 389 | mock_git_refs.side_effect = ['', '1234'] | ||
| 390 | |||
| 391 | self.assertTrue(self._superproject._Fetch()) | ||
| 392 | self.assertEqual(mock_git_command.call_args.args,(None, [ | ||
| 393 | 'fetch', 'http://localhost/superproject', '--depth', '1', | ||
| 394 | '--force', '--no-tags', '--filter', 'blob:none', | ||
| 395 | 'refs/heads/main:refs/heads/main' | ||
| 396 | ])) | ||
| 397 | |||
| 398 | # If branch for revision exists, set as --negotiation-tip. | ||
| 399 | self.assertTrue(self._superproject._Fetch()) | ||
| 400 | self.assertEqual(mock_git_command.call_args.args,(None, [ | ||
| 401 | 'fetch', 'http://localhost/superproject', '--depth', '1', | ||
| 402 | '--force', '--no-tags', '--filter', 'blob:none', | ||
| 403 | '--negotiation-tip', '1234', | ||
| 404 | 'refs/heads/main:refs/heads/main' | ||
| 405 | ])) | ||
