Move git repo creation into tests/lib.py
This way it can be shared with test_server.py
(cherry picked from commit 02f757d231)
			
			
This commit is contained in:
		
							parent
							
								
									087b0fe8c6
								
							
						
					
					
						commit
						136f9d877a
					
				
							
								
								
									
										82
									
								
								tests/lib.py
									
									
									
									
									
								
							
							
						
						
									
										82
									
								
								tests/lib.py
									
									
									
									
									
								
							| @ -14,10 +14,14 @@ | |||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with this program.  If not, see <http://www.gnu.org/licenses/>. | # along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
| # | # | ||||||
|  | import os | ||||||
| import sys | import sys | ||||||
| from contextlib import contextmanager | from contextlib import contextmanager | ||||||
| import magic | import magic | ||||||
| from io import StringIO | from io import StringIO | ||||||
|  | import shutil | ||||||
|  | import subprocess | ||||||
|  | import tempfile | ||||||
| 
 | 
 | ||||||
| @contextmanager | @contextmanager | ||||||
| def captured_output(): | def captured_output(): | ||||||
| @ -42,3 +46,81 @@ def get_file_magic(filename): | |||||||
|     finally: |     finally: | ||||||
|         ms.close() |         ms.close() | ||||||
|     return details |     return details | ||||||
|  | 
 | ||||||
|  | def create_git_repo(): | ||||||
|  |     """Create a git repo in a tmpdir | ||||||
|  | 
 | ||||||
|  |     Call this from setUpClass() | ||||||
|  | 
 | ||||||
|  |     This returns the following fields: | ||||||
|  |     * repodir - the directory holding the repository | ||||||
|  |     * test_results - A dict with information to use for the tests | ||||||
|  |     * first_commit - hash of the first commit | ||||||
|  |     """ | ||||||
|  |     repodir = tempfile.mkdtemp(prefix="git-rpm-test.") | ||||||
|  |     # Create a local git repo in a temporary directory, populate it with files. | ||||||
|  |     cmd = ["git", "init", repodir] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  | 
 | ||||||
|  |     oldcwd = os.getcwd() | ||||||
|  |     os.chdir(repodir) | ||||||
|  |     cmd = ["git", "config", "user.email", "test@testing.localhost"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  | 
 | ||||||
|  |     # Hold the expected file paths for the tests | ||||||
|  |     test_results = {"first": [], "second": [], "branch": []} | ||||||
|  |     # Add some files | ||||||
|  |     results_path = "./tests/pylorax/results/" | ||||||
|  |     for f in ["full-recipe.toml", "minimal.toml", "modules-only.toml"]: | ||||||
|  |         shutil.copy2(os.path.join(oldcwd, results_path, f), repodir) | ||||||
|  |         test_results["first"].append(f) | ||||||
|  | 
 | ||||||
|  |     cmd = ["git", "add", "*.toml"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  |     cmd = ["git", "commit", "-m", "first files"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  |     cmd = ["git", "tag", "v1.0.0"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  | 
 | ||||||
|  |     # Get the commit hash | ||||||
|  |     cmd = ["git", "log", "--pretty=%H"] | ||||||
|  |     first_commit = subprocess.check_output(cmd).decode("UTF-8").strip() | ||||||
|  | 
 | ||||||
|  |     # 2nd commit adds to 1st commit | ||||||
|  |     test_results["second"] = test_results["first"].copy() | ||||||
|  | 
 | ||||||
|  |     # Add some more files | ||||||
|  |     os.makedirs(os.path.join(repodir, "only-bps/")) | ||||||
|  |     for f in ["packages-only.toml", "groups-only.toml"]: | ||||||
|  |         shutil.copy2(os.path.join(oldcwd, results_path, f), os.path.join(repodir, "only-bps/")) | ||||||
|  |         test_results["second"].append(os.path.join("only-bps/", f)) | ||||||
|  |     test_results["second"] = sorted(test_results["second"]) | ||||||
|  | 
 | ||||||
|  |     cmd = ["git", "add", "*.toml"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  |     cmd = ["git", "commit", "-m", "second files"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  |     cmd = ["git", "tag", "v1.1.0"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  | 
 | ||||||
|  |     # Make a branch for some other files | ||||||
|  |     cmd = ["git", "checkout", "-b", "custom-branch"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  | 
 | ||||||
|  |     # 3nd commit adds to 2nd commit | ||||||
|  |     test_results["branch"] = test_results["second"].copy() | ||||||
|  | 
 | ||||||
|  |     # Add some files to the new branch | ||||||
|  |     for f in ["custom-base.toml", "repos-git.toml"]: | ||||||
|  |         shutil.copy2(os.path.join(oldcwd, results_path, f), repodir) | ||||||
|  |         test_results["branch"].append(f) | ||||||
|  |     test_results["branch"] = sorted(test_results["branch"]) | ||||||
|  | 
 | ||||||
|  |     cmd = ["git", "add", "*.toml"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  |     cmd = ["git", "commit", "-m", "branch files"] | ||||||
|  |     subprocess.check_call(cmd) | ||||||
|  | 
 | ||||||
|  |     os.chdir(oldcwd) | ||||||
|  | 
 | ||||||
|  |     return (repodir, test_results, first_commit) | ||||||
|  | |||||||
| @ -19,94 +19,18 @@ import pytoml as toml | |||||||
| import rpm | import rpm | ||||||
| import shutil | import shutil | ||||||
| import stat | import stat | ||||||
| import subprocess |  | ||||||
| import tarfile | import tarfile | ||||||
| import tempfile | import tempfile | ||||||
| import unittest | import unittest | ||||||
| 
 | 
 | ||||||
|  | from ..lib import create_git_repo | ||||||
| from pylorax.api.gitrpm import GitArchiveTarball, GitRpmBuild, make_git_rpm, create_gitrpm_repo | from pylorax.api.gitrpm import GitArchiveTarball, GitRpmBuild, make_git_rpm, create_gitrpm_repo | ||||||
| from pylorax.sysutils import joinpaths | from pylorax.sysutils import joinpaths | ||||||
| 
 | 
 | ||||||
| def _setup_git_repo(self): |  | ||||||
|     """Setup a git repo in a tmpdir, storing details into self |  | ||||||
| 
 |  | ||||||
|     Call this from setUpClass() |  | ||||||
|     """ |  | ||||||
|     self.repodir = tempfile.mkdtemp(prefix="git-rpm-test.") |  | ||||||
|     # Create a local git repo in a temporary directory, populate it with files. |  | ||||||
|     cmd = ["git", "init", self.repodir] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
| 
 |  | ||||||
|     oldcwd = os.getcwd() |  | ||||||
|     os.chdir(self.repodir) |  | ||||||
|     cmd = ["git", "config", "user.email", "test@testing.localhost"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
| 
 |  | ||||||
|     # Hold the expected file paths for the tests |  | ||||||
|     self.test_results = {"first": [], "second": [], "branch": []} |  | ||||||
|     # Add some files |  | ||||||
|     results_path = "./tests/pylorax/results/" |  | ||||||
|     for f in ["full-recipe.toml", "minimal.toml", "modules-only.toml"]: |  | ||||||
|         shutil.copy2(os.path.join(oldcwd, results_path, f), self.repodir) |  | ||||||
|         self.test_results["first"].append(f) |  | ||||||
| 
 |  | ||||||
|     cmd = ["git", "add", "*.toml"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
|     cmd = ["git", "commit", "-m", "first files"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
|     cmd = ["git", "tag", "v1.0.0"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
| 
 |  | ||||||
|     # Get the commit hash |  | ||||||
|     cmd = ["git", "log", "--pretty=%H"] |  | ||||||
|     self.first_commit = subprocess.check_output(cmd).decode("UTF-8").strip() |  | ||||||
| 
 |  | ||||||
|     # 2nd commit adds to 1st commit |  | ||||||
|     self.test_results["second"] = self.test_results["first"].copy() |  | ||||||
| 
 |  | ||||||
|     # Add some more files |  | ||||||
|     os.makedirs(os.path.join(self.repodir, "only-bps/")) |  | ||||||
|     for f in ["packages-only.toml", "groups-only.toml"]: |  | ||||||
|         shutil.copy2(os.path.join(oldcwd, results_path, f), os.path.join(self.repodir, "only-bps/")) |  | ||||||
|         self.test_results["second"].append(os.path.join("only-bps/", f)) |  | ||||||
|     self.test_results["second"] = sorted(self.test_results["second"]) |  | ||||||
| 
 |  | ||||||
|     cmd = ["git", "add", "*.toml"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
|     cmd = ["git", "commit", "-m", "second files"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
|     cmd = ["git", "tag", "v1.1.0"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
| 
 |  | ||||||
|     # Make a branch for some other files |  | ||||||
|     cmd = ["git", "checkout", "-b", "custom-branch"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
| 
 |  | ||||||
|     # 3nd commit adds to 2nd commit |  | ||||||
|     self.test_results["branch"] = self.test_results["second"].copy() |  | ||||||
| 
 |  | ||||||
|     # Add some files to the new branch |  | ||||||
|     for f in ["custom-base.toml", "repos-git.toml"]: |  | ||||||
|         shutil.copy2(os.path.join(oldcwd, results_path, f), self.repodir) |  | ||||||
|         self.test_results["branch"].append(f) |  | ||||||
|     self.test_results["branch"] = sorted(self.test_results["branch"]) |  | ||||||
| 
 |  | ||||||
|     cmd = ["git", "add", "*.toml"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
|     cmd = ["git", "commit", "-m", "branch files"] |  | ||||||
|     subprocess.check_call(cmd) |  | ||||||
| 
 |  | ||||||
|     os.chdir(oldcwd) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| class GitArchiveTest(unittest.TestCase): | class GitArchiveTest(unittest.TestCase): | ||||||
|     @classmethod |     @classmethod | ||||||
|     def setUpClass(self): |     def setUpClass(self): | ||||||
|         self.repodir = None |         (self.repodir, self.test_results, self.first_commit) = create_git_repo() | ||||||
|         self.first_commit = None |  | ||||||
|         self.test_results = {} |  | ||||||
| 
 |  | ||||||
|         _setup_git_repo(self) |  | ||||||
| 
 | 
 | ||||||
|     @classmethod |     @classmethod | ||||||
|     def tearDownClass(self): |     def tearDownClass(self): | ||||||
| @ -211,11 +135,7 @@ class GitArchiveTest(unittest.TestCase): | |||||||
| class GitRpmTest(unittest.TestCase): | class GitRpmTest(unittest.TestCase): | ||||||
|     @classmethod |     @classmethod | ||||||
|     def setUpClass(self): |     def setUpClass(self): | ||||||
|         self.repodir = None |         (self.repodir, self.test_results, self.first_commit) = create_git_repo() | ||||||
|         self.first_commit = None |  | ||||||
|         self.test_results = {} |  | ||||||
| 
 |  | ||||||
|         _setup_git_repo(self) |  | ||||||
| 
 | 
 | ||||||
|     @classmethod |     @classmethod | ||||||
|     def tearDownClass(self): |     def tearDownClass(self): | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user