ScriptCollection 3.5.0__py3-none-any.whl → 3.5.1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- ScriptCollection/ScriptCollectionCore.py +15 -15
- ScriptCollection/TasksForCommonProjectStructure.py +2 -1
- {ScriptCollection-3.5.0.dist-info → ScriptCollection-3.5.1.dist-info}/METADATA +1 -1
- {ScriptCollection-3.5.0.dist-info → ScriptCollection-3.5.1.dist-info}/RECORD +7 -7
- {ScriptCollection-3.5.0.dist-info → ScriptCollection-3.5.1.dist-info}/WHEEL +0 -0
- {ScriptCollection-3.5.0.dist-info → ScriptCollection-3.5.1.dist-info}/entry_points.txt +0 -0
- {ScriptCollection-3.5.0.dist-info → ScriptCollection-3.5.1.dist-info}/top_level.txt +0 -0
| @@ -29,7 +29,7 @@ from .ProgramRunnerPopen import ProgramRunnerPopen | |
| 29 29 | 
             
            from .ProgramRunnerEpew import ProgramRunnerEpew, CustomEpewArgument
         | 
| 30 30 |  | 
| 31 31 |  | 
| 32 | 
            -
            version = "3.5. | 
| 32 | 
            +
            version = "3.5.1"
         | 
| 33 33 | 
             
            __version__ = version
         | 
| 34 34 |  | 
| 35 35 |  | 
| @@ -73,15 +73,15 @@ class ScriptCollectionCore: | |
| 73 73 |  | 
| 74 74 | 
             
                @GeneralUtilities.check_arguments
         | 
| 75 75 | 
             
                def replace_version_in_dockerfile_file(self, dockerfile: str, new_version_value: str) -> None:
         | 
| 76 | 
            -
                    GeneralUtilities.write_text_to_file(dockerfile, re.sub("ARG Version=\"\\d+\\.\\d+\\.\\d+\"", f"ARG Version=\"{new_version_value}\"", | 
| 76 | 
            +
                    GeneralUtilities.write_text_to_file(dockerfile, re.sub("ARG Version=\"\\d+\\.\\d+\\.\\d+\"", f"ARG Version=\"{new_version_value}\"", GeneralUtilities.read_text_from_file(dockerfile)))
         | 
| 77 77 |  | 
| 78 78 | 
             
                @GeneralUtilities.check_arguments
         | 
| 79 79 | 
             
                def replace_version_in_python_file(self, file: str, new_version_value: str):
         | 
| 80 | 
            -
                    GeneralUtilities.write_text_to_file(file, re.sub("version = \"\\d+\\.\\d+\\.\\d+\"", f"version = \"{new_version_value}\"", | 
| 80 | 
            +
                    GeneralUtilities.write_text_to_file(file, re.sub("version = \"\\d+\\.\\d+\\.\\d+\"", f"version = \"{new_version_value}\"", GeneralUtilities.read_text_from_file(file)))
         | 
| 81 81 |  | 
| 82 82 | 
             
                @GeneralUtilities.check_arguments
         | 
| 83 83 | 
             
                def replace_version_in_ini_file(self, file: str, new_version_value: str):
         | 
| 84 | 
            -
                    GeneralUtilities.write_text_to_file(file, re.sub("version = \\d+\\.\\d+\\.\\d+", f"version = {new_version_value}", | 
| 84 | 
            +
                    GeneralUtilities.write_text_to_file(file, re.sub("version = \\d+\\.\\d+\\.\\d+", f"version = {new_version_value}", GeneralUtilities.read_text_from_file(file)))
         | 
| 85 85 |  | 
| 86 86 | 
             
                @GeneralUtilities.check_arguments
         | 
| 87 87 | 
             
                def replace_version_in_nuspec_file(self, nuspec_file: str, new_version: str) -> None:
         | 
| @@ -90,7 +90,7 @@ class ScriptCollectionCore: | |
| 90 90 | 
             
                    versiononlyregex = f"^{versionregex}$"
         | 
| 91 91 | 
             
                    pattern = re.compile(versiononlyregex)
         | 
| 92 92 | 
             
                    if pattern.match(new_version):
         | 
| 93 | 
            -
                        GeneralUtilities.write_text_to_file(nuspec_file, re.sub(f"<version>{versionregex}<\\/version>", | 
| 93 | 
            +
                        GeneralUtilities.write_text_to_file(nuspec_file, re.sub(f"<version>{versionregex}<\\/version>", f"<version>{new_version}</version>", GeneralUtilities.read_text_from_file(nuspec_file)))
         | 
| 94 94 | 
             
                    else:
         | 
| 95 95 | 
             
                        raise ValueError(f"Version '{new_version}' does not match version-regex '{versiononlyregex}'")
         | 
| 96 96 |  | 
| @@ -101,7 +101,7 @@ class ScriptCollectionCore: | |
| 101 101 | 
             
                    pattern = re.compile(versiononlyregex)
         | 
| 102 102 | 
             
                    if pattern.match(current_version):
         | 
| 103 103 | 
             
                        for tag in ["Version", "AssemblyVersion", "FileVersion"]:
         | 
| 104 | 
            -
                            GeneralUtilities.write_text_to_file(csproj_file, re.sub(f"<{tag}>{versionregex}(.\\d+)?<\\/{tag}>", | 
| 104 | 
            +
                            GeneralUtilities.write_text_to_file(csproj_file, re.sub(f"<{tag}>{versionregex}(.\\d+)?<\\/{tag}>", f"<{tag}>{current_version}</{tag}>", GeneralUtilities.read_text_from_file(csproj_file)))
         | 
| 105 105 | 
             
                    else:
         | 
| 106 106 | 
             
                        raise ValueError(f"Version '{current_version}' does not match version-regex '{versiononlyregex}'")
         | 
| 107 107 |  | 
| @@ -109,7 +109,7 @@ class ScriptCollectionCore: | |
| 109 109 | 
             
                def push_nuget_build_artifact(self, nupkg_file: str, registry_address: str, api_key: str, verbosity: int = 1):
         | 
| 110 110 | 
             
                    nupkg_file_name = os.path.basename(nupkg_file)
         | 
| 111 111 | 
             
                    nupkg_file_folder = os.path.dirname(nupkg_file)
         | 
| 112 | 
            -
                    self.run_program("dotnet", f"nuget push {nupkg_file_name} --force-english-output --source {registry_address} --api-key {api_key}", | 
| 112 | 
            +
                    self.run_program("dotnet", f"nuget push {nupkg_file_name} --force-english-output --source {registry_address} --api-key {api_key}", nupkg_file_folder, verbosity)
         | 
| 113 113 |  | 
| 114 114 | 
             
                @GeneralUtilities.check_arguments
         | 
| 115 115 | 
             
                def dotnet_build(self, repository_folder: str, projectname: str, configuration: str):
         | 
| @@ -142,7 +142,7 @@ class ScriptCollectionCore: | |
| 142 142 |  | 
| 143 143 | 
             
                @GeneralUtilities.check_arguments
         | 
| 144 144 | 
             
                def get_parent_commit_ids_of_commit(self, repository_folder: str, commit_id: str) -> str:
         | 
| 145 | 
            -
                    return self.run_program("git", f'log --pretty=%P -n 1 "{commit_id}"', | 
| 145 | 
            +
                    return self.run_program("git", f'log --pretty=%P -n 1 "{commit_id}"', repository_folder, throw_exception_if_exitcode_is_not_zero=True)[1].replace("\r", "").replace("\n", "").split(" ")
         | 
| 146 146 |  | 
| 147 147 | 
             
                @GeneralUtilities.check_arguments
         | 
| 148 148 | 
             
                def get_all_authors_and_committers_of_repository(self, repository_folder: str, subfolder: str = None, verbosity: int = 1) -> list[tuple[str, str]]:
         | 
| @@ -151,7 +151,7 @@ class ScriptCollectionCore: | |
| 151 151 | 
             
                        subfolder_argument = ""
         | 
| 152 152 | 
             
                    else:
         | 
| 153 153 | 
             
                        subfolder_argument = f" -- {subfolder}"
         | 
| 154 | 
            -
                    log_result = self.run_program("git", f'log --pretty=%aN{space_character}%aE%n%cN{space_character}%cE HEAD{subfolder_argument}', | 
| 154 | 
            +
                    log_result = self.run_program("git", f'log --pretty=%aN{space_character}%aE%n%cN{space_character}%cE HEAD{subfolder_argument}', repository_folder, verbosity=0)
         | 
| 155 155 | 
             
                    plain_content: list[str] = list(set([line for line in log_result[1].split("\n") if len(line) > 0]))
         | 
| 156 156 | 
             
                    result: list[tuple[str, str]] = []
         | 
| 157 157 | 
             
                    for item in plain_content:
         | 
| @@ -166,7 +166,7 @@ class ScriptCollectionCore: | |
| 166 166 | 
             
                def get_commit_ids_between_dates(self, repository_folder: str, since: datetime, until: datetime, ignore_commits_which_are_not_in_history_of_head: bool = True) -> None:
         | 
| 167 167 | 
             
                    since_as_string = self.__datetime_to_string_for_git(since)
         | 
| 168 168 | 
             
                    until_as_string = self.__datetime_to_string_for_git(until)
         | 
| 169 | 
            -
                    result = filter(lambda line: not GeneralUtilities.string_is_none_or_whitespace(line), | 
| 169 | 
            +
                    result = filter(lambda line: not GeneralUtilities.string_is_none_or_whitespace(line), self.run_program("git", f'log --since "{since_as_string}" --until "{until_as_string}" --pretty=format:"%H" --no-patch',                                         repository_folder, throw_exception_if_exitcode_is_not_zero=True)[1].split("\n").replace("\r", ""))
         | 
| 170 170 | 
             
                    if ignore_commits_which_are_not_in_history_of_head:
         | 
| 171 171 | 
             
                        result = [commit_id for commit_id in result if self.git_commit_is_ancestor(repository_folder, commit_id)]
         | 
| 172 172 | 
             
                    return result
         | 
| @@ -187,7 +187,7 @@ class ScriptCollectionCore: | |
| 187 187 |  | 
| 188 188 | 
             
                @GeneralUtilities.check_arguments
         | 
| 189 189 | 
             
                def __git_changes_helper(self, repository_folder: str, arguments_as_array: list[str]) -> bool:
         | 
| 190 | 
            -
                    lines = GeneralUtilities.string_to_lines(self.run_program_argsasarray("git", arguments_as_array, repository_folder, | 
| 190 | 
            +
                    lines = GeneralUtilities.string_to_lines(self.run_program_argsasarray("git", arguments_as_array, repository_folder, throw_exception_if_exitcode_is_not_zero=True, verbosity=0)[1], False)
         | 
| 191 191 | 
             
                    for line in lines:
         | 
| 192 192 | 
             
                        if GeneralUtilities.string_has_content(line):
         | 
| 193 193 | 
             
                            return True
         | 
| @@ -451,7 +451,7 @@ class ScriptCollectionCore: | |
| 451 451 | 
             
                    return tags
         | 
| 452 452 |  | 
| 453 453 | 
             
                @GeneralUtilities.check_arguments
         | 
| 454 | 
            -
                def git_move_tags_to_another_branch(self, repository: str, tag_source_branch: str, tag_target_branch: str, | 
| 454 | 
            +
                def git_move_tags_to_another_branch(self, repository: str, tag_source_branch: str, tag_target_branch: str, sign: bool = False, message: str = None) -> None:
         | 
| 455 455 | 
             
                    tags = self.git_get_tags(repository)
         | 
| 456 456 | 
             
                    tags_count = len(tags)
         | 
| 457 457 | 
             
                    counter = 0
         | 
| @@ -712,7 +712,7 @@ class ScriptCollectionCore: | |
| 712 712 | 
             
                        self.git_remove_branch(repository, sourcebranch)
         | 
| 713 713 |  | 
| 714 714 | 
             
                @GeneralUtilities.check_arguments
         | 
| 715 | 
            -
                def sc_organize_lines_in_file(self, file: str, encoding: str, sort: bool = False, remove_duplicated_lines: bool = False, ignore_first_line: bool = False, | 
| 715 | 
            +
                def sc_organize_lines_in_file(self, file: str, encoding: str, sort: bool = False, remove_duplicated_lines: bool = False, ignore_first_line: bool = False, remove_empty_lines: bool = True, ignored_start_character: list = list()) -> int:
         | 
| 716 716 | 
             
                    if os.path.isfile(file):
         | 
| 717 717 |  | 
| 718 718 | 
             
                        # read file
         | 
| @@ -1303,7 +1303,7 @@ class ScriptCollectionCore: | |
| 1303 1303 | 
             
                        f"stderr: {GeneralUtilities.str_none_safe(str(r.stderr))})"
         | 
| 1304 1304 |  | 
| 1305 1305 | 
             
                @GeneralUtilities.check_arguments
         | 
| 1306 | 
            -
                def register_mock_program_call(self, program: str, argument: str, workingdirectory: str, result_exit_code: int, result_stdout: str, result_stderr: str, | 
| 1306 | 
            +
                def register_mock_program_call(self, program: str, argument: str, workingdirectory: str, result_exit_code: int, result_stdout: str, result_stderr: str, result_pid: int, amount_of_expected_calls=1):
         | 
| 1307 1307 | 
             
                    "This function is for test-purposes only"
         | 
| 1308 1308 | 
             
                    for _ in itertools.repeat(None, amount_of_expected_calls):
         | 
| 1309 1309 | 
             
                        mock_call = ScriptCollectionCore.__MockProgramCall()
         | 
| @@ -1435,7 +1435,7 @@ class ScriptCollectionCore: | |
| 1435 1435 | 
             
                    self.run_program("openssl", f'req -new -newkey ec -pkeyopt ec_paramgen_curve:prime256v1 -days {days_until_expire} -nodes -x509 -subj /C={subj_c}/ST={subj_st}/L={subj_l}/O={subj_o}/CN={name}/OU={subj_ou} -passout pass:{password} -keyout {name}.key -out {name}.crt', folder)
         | 
| 1436 1436 |  | 
| 1437 1437 | 
             
                @GeneralUtilities.check_arguments
         | 
| 1438 | 
            -
                def generate_certificate(self, folder: str,  domain: str, filename: str, subj_c: str, subj_st: str, subj_l: str, subj_o: str, subj_ou: str, | 
| 1438 | 
            +
                def generate_certificate(self, folder: str,  domain: str, filename: str, subj_c: str, subj_st: str, subj_l: str, subj_o: str, subj_ou: str, days_until_expire: int = None, password: str = None) -> None:
         | 
| 1439 1439 | 
             
                    if days_until_expire is None:
         | 
| 1440 1440 | 
             
                        days_until_expire = 397
         | 
| 1441 1441 | 
             
                    if password is None:
         | 
| @@ -2375,7 +2375,8 @@ class TasksForCommonProjectStructure: | |
| 2375 2375 | 
             
                    # prepare
         | 
| 2376 2376 | 
             
                    self.assert_no_uncommitted_changes(repository_folder)
         | 
| 2377 2377 | 
             
                    self.__sc.git_checkout(repository_folder, merge_source_branch)
         | 
| 2378 | 
            -
                     | 
| 2378 | 
            +
                    if not "--prevent-dependency-update" in generic_prepare_new_release_arguments.commandline_arguments:
         | 
| 2379 | 
            +
                        self.generic_update_dependencies(repository_folder)
         | 
| 2379 2380 | 
             
                    self.merge_to_main_branch(repository_folder, merge_source_branch, verbosity=verbosity, fast_forward_source_branch=True)
         | 
| 2380 2381 | 
             
                    self.__sc.git_commit(build_repository_folder, "Updated submodule due to merge to main-branch.")
         | 
| 2381 2382 |  | 
| @@ -3,12 +3,12 @@ ScriptCollection/GeneralUtilities.py,sha256=Mcp6ghb6AbS1KsOjEnRw3x4a4mBrAZ6DAjV2 | |
| 3 3 | 
             
            ScriptCollection/ProgramRunnerBase.py,sha256=2kyOuoM3oFjBfLc9Q5t5RTz7Ya2CjUxFtB1rBBDmnjU,1937
         | 
| 4 4 | 
             
            ScriptCollection/ProgramRunnerEpew.py,sha256=nIzY4dG6W-xEpkeoTbozwNZtFSIo-bU_W6t6u1AZKtE,6275
         | 
| 5 5 | 
             
            ScriptCollection/ProgramRunnerPopen.py,sha256=kV7KVuDenKjOyNBFurMTcuhuLuLZ74MaaSrwaPjaHCs,3158
         | 
| 6 | 
            -
            ScriptCollection/ScriptCollectionCore.py,sha256= | 
| 7 | 
            -
            ScriptCollection/TasksForCommonProjectStructure.py,sha256= | 
| 6 | 
            +
            ScriptCollection/ScriptCollectionCore.py,sha256=HOrGzg_XZVDLBILfY7LPS-a3G3k9uIamI3oiSLYzlP4,92041
         | 
| 7 | 
            +
            ScriptCollection/TasksForCommonProjectStructure.py,sha256=8GA4Ko7xmELPTMTH_is86twJZ-UyWoDCiH5Z3boJ0FI,173825
         | 
| 8 8 | 
             
            ScriptCollection/UpdateCertificates.py,sha256=3C_E9og5SZec35aD3BFYLchzJtonsg1KR4enFCb5Jzk,7914
         | 
| 9 9 | 
             
            ScriptCollection/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
         | 
| 10 | 
            -
            ScriptCollection-3.5. | 
| 11 | 
            -
            ScriptCollection-3.5. | 
| 12 | 
            -
            ScriptCollection-3.5. | 
| 13 | 
            -
            ScriptCollection-3.5. | 
| 14 | 
            -
            ScriptCollection-3.5. | 
| 10 | 
            +
            ScriptCollection-3.5.1.dist-info/METADATA,sha256=rAK2osGWF6py3N0o3YHP8A-HSJRxXDXa94Cux2Ishjo,7648
         | 
| 11 | 
            +
            ScriptCollection-3.5.1.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
         | 
| 12 | 
            +
            ScriptCollection-3.5.1.dist-info/entry_points.txt,sha256=dwvB9HRGvqst5xlYIGmmwuFN7lBKhxvndmnNrQOfu8w,2153
         | 
| 13 | 
            +
            ScriptCollection-3.5.1.dist-info/top_level.txt,sha256=hY2hOVH0V0Ce51WB76zKkIWTUNwMUdHo4XDkR2vYVwg,17
         | 
| 14 | 
            +
            ScriptCollection-3.5.1.dist-info/RECORD,,
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
| 
            File without changes
         |