From e8dd1df17cb9447950180ed9e16fa538ffc9f601 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tom=C3=A1s=20Gonz=C3=A1lez?= Date: Thu, 23 Nov 2023 13:56:08 +0000 Subject: [PATCH 1/3] ci_script/action.yml: Add ci-flags for running ci.sh script MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit The ci-flags input will allow to call the ci.sh script with arguments and for them to be specified from each ci job that uses the composite workflow in question. Signed-off-by: Tomás González --- .github/actions/ci_script/action.yml | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/.github/actions/ci_script/action.yml b/.github/actions/ci_script/action.yml index ee3114b..75e6167 100644 --- a/.github/actions/ci_script/action.yml +++ b/.github/actions/ci_script/action.yml @@ -1,5 +1,10 @@ name: "CI script Tests" description: "Install and run Parsec with the Mbed Crypto provider" +inputs: + ci-flags: + required: true + default: "" + description: "Flags with which to run the ci.sh tests" runs: using: "composite" @@ -12,5 +17,5 @@ runs: ./target/debug/parsec -c ../tests/test_config.toml & shell: bash - name: Execute CI script - run: ./tests/ci.sh + run: ./tests/ci.sh ${{ inputs.ci-flags }} shell: bash From 6927e89df33ab4729b330663875ec1e6a3fa0c88 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tom=C3=A1s=20Gonz=C3=A1lez?= Date: Thu, 23 Nov 2023 14:01:06 +0000 Subject: [PATCH 2/3] utils/dependency_cross_matcher.py: Add dependency cross matching MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Add a script to check for mismatches in dependencies in the repository. Mismatches are two different versions of the same dependency. Signed-off-by: Tomás González --- utils/dependency_cross_matcher.py | 75 +++++++++++++++++++++++++++++++ 1 file changed, 75 insertions(+) create mode 100644 utils/dependency_cross_matcher.py diff --git a/utils/dependency_cross_matcher.py b/utils/dependency_cross_matcher.py new file mode 100644 index 0000000..fabbe72 --- /dev/null +++ b/utils/dependency_cross_matcher.py @@ -0,0 +1,75 @@ +import argparse +import re +import os +import subprocess +import sys + + +def run_cargo_tree(path): + cmd = 'cargo tree --all-features -d' + prev_dir = os.getcwd() + os.chdir(os.path.join(path)) + return subprocess.check_output(cmd, shell=True).decode() + + +def run_deps_mismatcher(lines): + pat = re.compile('([a-zA-Z]\S+)\s(v\S+)') + deps = dict() + for line in lines.split('\n'): + m = pat.search(line) + if m is not None: + if m.group(1) in deps.keys(): + if m.group(2) not in deps[m.group(1)]: + deps[m.group(1)].append(m.group(2)) + else: + deps[m.group(1)] = [m.group(2)] + return deps + + +def get_deps_with_more_than_1v(deps_and_versions): + new_dict = dict() + for dep_name, versions in deps_and_versions.items(): + if len(versions) > 1: + new_dict[dep_name] = versions + return new_dict + + +def print_deps(deps_and_versions): + for dep_name, versions in deps_and_versions.items(): + print(f"{dep_name:<25} {versions}") + + +def main(argv=[], prog_name=''): + parser = argparse.ArgumentParser(prog='DependencyCrossmatcher', + description='Checks the version mismatches for dependencies ' + 'in Cargo based repositories') + parser.add_argument('--deps_dir', + required=True, + help='Existing directory that contains the Cargo.toml for analyzing' + 'dependencies') + args = parser.parse_args() + + mismatches = run_deps_mismatcher(run_cargo_tree(args.deps_dir)) + print_deps(mismatches) + + mismatches = get_deps_with_more_than_1v(mismatches) + + print('---------------------mistmatches----------------------\n\n') + print_deps(mismatches) + + exceptions = { + 'base64': ['v0.13.1', 'v0.21.4'], + 'bitflags': ['v1.3.2', 'v2.4.1'], + 'nom': ['v5.1.3', 'v7.1.3'], + 'syn': ['v1.0.109', 'v2.0.38'], + 'yasna': ['v0.4.0', 'v0.5.2'], + } + + if exceptions != mismatches: + return 1 + + return 0 + + +if __name__ == '__main__': + sys.exit(main(sys.argv[1:], sys.argv[0])) From 409188d5516895f491a1924c10c67b0cf463f085 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tom=C3=A1s=20Gonz=C3=A1lez?= Date: Thu, 23 Nov 2023 13:47:10 +0000 Subject: [PATCH 3/3] ci/nightly: Add a dependency mismatcher job MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Add a dependency mismatcher job that checks whether any dependencies have more than one versions. Signed-off-by: Tomás González --- .github/workflows/nightly.yml | 17 +++++++++++++++++ tests/ci.sh | 34 ++++++++++++++++++++++++++++++++++ 2 files changed, 51 insertions(+) diff --git a/.github/workflows/nightly.yml b/.github/workflows/nightly.yml index 7b66771..5a36b45 100644 --- a/.github/workflows/nightly.yml +++ b/.github/workflows/nightly.yml @@ -42,3 +42,20 @@ jobs: run: cargo install cargo-audit - name: Execute cargo audit run: cargo audit + + mismatcher: + name: Check for mismatched dependencies (those that have more than one version) + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + with: + ref: "${{ github.event.inputs.rev }}" + - name: Install Rust MSRV + uses: actions-rust-lang/setup-rust-toolchain@v1 + with: + toolchain: stable + rustflags: "" + - name: Execute CI script + uses: ./.github/actions/ci_script + with: + ci-flags: "mismatcher" diff --git a/tests/ci.sh b/tests/ci.sh index f40eeeb..28fc426 100755 --- a/tests/ci.sh +++ b/tests/ci.sh @@ -5,10 +5,44 @@ set -xeuf -o pipefail +error_msg () { + echo "Error: $1" + exit 1 +} + # Points to Parsec's Unix Domain Socket on the CI export PARSEC_SERVICE_ENDPOINT="unix:/tmp/parsec.sock" export RUST_LOG=error +################## +# Get Parameters # +################## +MISMATCHER= +while [ "$#" -gt 0 ]; do + case "$1" in + mismatcher ) + MISMATCHER="True" + ;; + *) + error_msg "Unknown argument: $1" + ;; + esac + shift +done + +######################### +# Dependency mismatcher # +######################### +if [ "$MISMATCHER" = "True" ]; then + python3 $(pwd)/utils/dependency_cross_matcher.py --deps_dir $(pwd) + mismatcher_result=$? + if [ "$mismatcher_result" -ne 0 ]; then + error_msg "Found dependencies version mismatches" + fi + + exit 0 +fi + ######### # Build # #########