From f5a9fc81788563f2f807920d79eb2a359741db5a Mon Sep 17 00:00:00 2001 From: x-mass <36629999+x-mass@users.noreply.github.com> Date: Fri, 8 Dec 2023 11:55:14 +0700 Subject: [PATCH] Use reusable workflow in testing action (#244) * Revert perf test disabling * Use reusable workflow in testing action --- .github/workflows/publish-results.yml | 13 ++ .github/workflows/pull-request.yml | 38 +++++ .github/workflows/run_tests.yml | 145 ------------------ test/CMakeLists.txt | 38 +++-- .../systems/plonk/placeholder/performance.cpp | 4 +- 5 files changed, 77 insertions(+), 161 deletions(-) create mode 100644 .github/workflows/publish-results.yml create mode 100644 .github/workflows/pull-request.yml delete mode 100644 .github/workflows/run_tests.yml diff --git a/.github/workflows/publish-results.yml b/.github/workflows/publish-results.yml new file mode 100644 index 000000000..4b7b9f332 --- /dev/null +++ b/.github/workflows/publish-results.yml @@ -0,0 +1,13 @@ +# Needed to publish test results in fork +name: Testing Callback + +on: + workflow_run: + workflows: ["PR Testing"] + types: + - completed + +jobs: + call-reusable-workflow: + name: Call Reusable Testing Callback Workflow + uses: NilFoundation/ci-cd/.github/workflows/reusable-crypto3-publish-result.yml@v1 diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml new file mode 100644 index 000000000..a0968e740 --- /dev/null +++ b/.github/workflows/pull-request.yml @@ -0,0 +1,38 @@ +name: PR Testing + +on: + pull_request: + types: + - opened + - synchronize + +jobs: + handle-syncwith: + name: Call Reusable SyncWith Handler + uses: NilFoundation/ci-cd/.github/workflows/reusable-handle-syncwith.yml@v1 + with: + ci-cd-ref: 'v1' + secrets: inherit + + matrix-test: + name: Call Reusable Crypto3 Testing + needs: + - handle-syncwith + uses: NilFoundation/ci-cd/.github/workflows/reusable-crypto3-testing.yml@v1.1.0 + secrets: inherit + with: + submodules-refs: ${{ needs.handle-syncwith.outputs.prs-refs }} + concurrency: 2 # adjust if fails with OOM + targets: | + crypto3_zk_commitment_fold_polynomial_test + crypto3_zk_commitment_fri_test + crypto3_zk_commitment_lpc_test + crypto3_zk_commitment_kzg_test + crypto3_zk_systems_plonk_placeholder_placeholder_test + crypto3_zk_commitment_powers_of_tau_test + crypto3_zk_commitment_proof_of_knowledge_test + crypto3_zk_commitment_r1cs_gg_ppzksnark_mpc_test + crypto3_zk_math_expression_test + crypto3_zk_systems_plonk_plonk_constraint_test + crypto3_zk_commitment_proof_of_knowledge_test + crypto3_zk_transcript_transcript_test diff --git a/.github/workflows/run_tests.yml b/.github/workflows/run_tests.yml deleted file mode 100644 index 3086f1600..000000000 --- a/.github/workflows/run_tests.yml +++ /dev/null @@ -1,145 +0,0 @@ -name: Run tests - -on: - push: - branches: - - master - pull_request: - - # Allows you to run this workflow manually from the Actions tab - #workflow_dispatch: - -env: - SUITE_REPO: "NilFoundation/crypto3" - LIB_NAME: "zk" - CACHE_NAME: "checkout-job-cache" - -jobs: - handle-syncwith: - if: github.event_name == 'pull_request' - name: Call Reusable SyncWith Handler - uses: NilFoundation/ci-cd/.github/workflows/reusable-handle-syncwith.yml@v1 - with: - ci-cd-ref: 'v1' - secrets: inherit - - checkout: - runs-on: [self-hosted, tests-runner] - needs: [handle-syncwith] - steps: - - name: Cleanup # TODO - move to scripts on runner - run: | - rm -rf ./* || true - rm -rf ./.??* || true - - - name: Checkout suite - uses: actions/checkout@v3 - with: - repository: ${{ env.SUITE_REPO }} - submodules: recursive - - - name: Checkout source code - uses: actions/checkout@v3 - with: - path: ./libs/${{ env.LIB_NAME }} - submodules: recursive - - - name: Checkout modules to specified refs - if: needs.handle-syncwith.outputs.prs-refs != '' - uses: NilFoundation/ci-cd/actions/recursive-checkout@v1 - with: - paths: | - ./** - !./**/.git/** - refs: ${{ needs.handle-syncwith.outputs.prs-refs }} - - - name: Cmake and build - env: - CMAKE_ARGS: " - -DCMAKE_BUILD_TYPE=Debug - -DBUILD_SHARED_LIBS=FALSE - -DBUILD_TESTS=TRUE - -DZK_PLACEHOLDER_PROFILING=TRUE - " - run: | - mkdir build - cd build - cmake ${{ env.CMAKE_ARGS }} .. - - - name: Archive build results - run: | - touch ${{ env.CACHE_NAME }}.tar.gz - tar -czf ${{ env.CACHE_NAME }}.tar.gz --exclude=${{ env.CACHE_NAME }}.tar.gz . - - - name: Cache archived job output - uses: actions/upload-artifact@v3 - with: - name: ${{ env.CACHE_NAME }} - path: ${{ env.CACHE_NAME }}.tar.gz - retention-days: 1 - - - run_tests: - runs-on: [self-hosted, tests-runner] - needs: [checkout] - strategy: - fail-fast: false - matrix: - target: [ - crypto3_zk_commitment_fold_polynomial_test, - crypto3_zk_commitment_fri_test, - crypto3_zk_commitment_lpc_test, - crypto3_zk_commitment_kzg_test, - crypto3_zk_systems_plonk_placeholder_placeholder_test, - crypto3_zk_commitment_powers_of_tau_test, - crypto3_zk_commitment_proof_of_knowledge_test, - crypto3_zk_commitment_r1cs_gg_ppzksnark_mpc_test, - crypto3_zk_math_expression_test, - crypto3_zk_systems_plonk_plonk_constraint_test, - crypto3_zk_commitment_proof_of_knowledge_test, - crypto3_zk_transcript_transcript_test - - # Performance tests pass, but they are excluded from here due to speed. - # crypto3_zk_commitment_lpc_performance_test - - # The following tests are temporarily failing. - # crypto3_zk_commitment_pedersen_test - # crypto3_zk_transcript_kimchi_transcript_test - # crypto3_zk_commitment_kimchi_pedersen_test - # crypto3_zk_commitment_type_traits_test - # crypto3_zk_relations_numeric_qap_test - # crypto3_zk_relations_numeric_sap_test - # crypto3_zk_relations_numeric_ssp_test - # crypto3_zk_routing_algorithms_test_routing_algorithms_test - # crypto3_zk_systems_pcd_r1cs_pcd_r1cs_mp_ppzkpcd_r1cs_mp_ppzkpcd_test - # crypto3_zk_systems_plonk_pickles_kimchi_test - # crypto3_zk_systems_plonk_pickles_oracles_test - - ] # Tests to execute - steps: - - name: Cleanup # TODO - move to scripts on runner - run: | - rm -rf ./* || true - rm -rf ./.??* || true - - - name: Upload checkout job cache - uses: actions/download-artifact@v3 - with: - name: ${{ env.CACHE_NAME }} - - - name: Extract artifacts - run: | - tar -xf ${{ env.CACHE_NAME }}.tar.gz - rm ${{ env.CACHE_NAME }}.tar.gz - - - name: Build - working-directory: ./build - run: cmake --build . -t ${{ matrix.target }} - - - name: Run test - working-directory: ./build - run: | - cd libs/${{ env.LIB_NAME }}/test - COLOR='\033[0;33m' - echo -e "${COLOR}${{ matrix.target }}" - ./${{ matrix.target }} diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 6bfecd49a..069096939 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -31,9 +31,19 @@ if(ZK_PLACEHOLDER_PROFILING) endif() macro(define_zk_test test) - get_filename_component(name ${test} NAME) string(REPLACE "/" "_" full_test_name ${CMAKE_WORKSPACE_NAME}_${CURRENT_PROJECT_NAME}_${test}_test) - cm_test(NAME ${full_test_name} SOURCES ${test}.cpp) + + set(additional_args "") + if(ENABLE_JUNIT_TEST_OUTPUT) + set(TEST_RESULTS_DIR "${CMAKE_CURRENT_BINARY_DIR}/junit_results") + set(TEST_LOGS_DIR "${TEST_RESULTS_DIR}/logs") + file(MAKE_DIRECTORY ${TEST_LOGS_DIR}) + + set(additional_args "--log_format=JUNIT" + "--log_sink=${TEST_LOGS_DIR}/${full_test_name}.xml") + endif() + + cm_test(NAME ${full_test_name} SOURCES ${test}.cpp ARGS ${additional_args}) target_include_directories(${full_test_name} PRIVATE "$" @@ -59,16 +69,18 @@ macro(define_zk_test test) endmacro() set(TESTS_NAMES + # FIXME: these targets are disabled because they fail compilation. Either fix them or remove (if not needed) + # "commitment/lpc_performance" TODO try to enable + # "commitment/pedersen" + # "commitment/type_traits" + "commitment/lpc" "commitment/fri" "commitment/kzg" "commitment/fold_polynomial" - "commitment/lpc_performance" - "commitment/pedersen" "commitment/proof_of_knowledge" "commitment/powers_of_tau" "commitment/r1cs_gg_ppzksnark_mpc" - "commitment/type_traits" "commitment/kimchi_pedersen" "math/expression" @@ -79,12 +91,12 @@ set(TESTS_NAMES # "relations/numeric/sap" # "relations/numeric/ssp" - "systems/plonk/pickles/pickles" + # "systems/plonk/pickles/pickles" "systems/plonk/pickles/kimchi" - "systems/plonk/pickles/oracles" + # "systems/plonk/pickles/oracles" "systems/plonk/pickles/to_field" "systems/plonk/pickles/to_group" - + "systems/plonk/placeholder/placeholder" "systems/plonk/placeholder/performance" @@ -92,15 +104,15 @@ set(TESTS_NAMES # "systems/pcd/r1cs_pcd/r1cs_sp_ppzkpcd/r1cs_sp_ppzkpcd" # "systems/ppzksnark/bacs_ppzksnark/bacs_ppzksnark" - "systems/ppzksnark/r1cs_gg_ppzksnark/r1cs_gg_ppzksnark" - "systems/ppzksnark/r1cs_gg_ppzksnark/r1cs_gg_ppzksnark_marshalling" - "systems/ppzksnark/r1cs_gg_ppzksnark/r1cs_gg_ppzksnark_tvm_marshalling" - "systems/ppzksnark/r1cs_ppzksnark/r1cs_ppzksnark" + # "systems/ppzksnark/r1cs_gg_ppzksnark/r1cs_gg_ppzksnark" + # "systems/ppzksnark/r1cs_gg_ppzksnark/r1cs_gg_ppzksnark_marshalling" + # "systems/ppzksnark/r1cs_gg_ppzksnark/r1cs_gg_ppzksnark_tvm_marshalling" + # "systems/ppzksnark/r1cs_ppzksnark/r1cs_ppzksnark" # "systems/ppzksnark/r1cs_se_ppzksnark/r1cs_se_ppzksnark" # "systems/ppzksnark/ram_ppzksnark/ram_ppzksnark" # "systems/ppzksnark/tbcs_ppzksnark/tbcs_ppzksnark" # "systems/ppzksnark/uscs_ppzksnark/uscs_ppzksnark" - "systems/ppzksnark/r1cs_gg_ppzksnark/r1cs_gg_ppzksnark_aggregation_conformity" + # "systems/ppzksnark/r1cs_gg_ppzksnark/r1cs_gg_ppzksnark_aggregation_conformity" "transcript/transcript" "transcript/kimchi_transcript" diff --git a/test/systems/plonk/placeholder/performance.cpp b/test/systems/plonk/placeholder/performance.cpp index 0f624685d..929a5828e 100644 --- a/test/systems/plonk/placeholder/performance.cpp +++ b/test/systems/plonk/placeholder/performance.cpp @@ -321,7 +321,7 @@ class placeholder_performance_test : public placeholder_performance_test_base { columns_rotations_type columns_rotations; }; -BOOST_AUTO_TEST_SUITE(placeholder_transpiler_suite, *boost::unit_test::disabled()) +BOOST_AUTO_TEST_SUITE(placeholder_transpiler_suite) BOOST_FIXTURE_TEST_CASE(placeholder_merkle_tree_poseidon_test, placeholder_performance_test<2>) { @@ -434,5 +434,3 @@ BOOST_FIXTURE_TEST_CASE(placeholder_large_fibonacci_test, placeholder_performanc } BOOST_AUTO_TEST_SUITE_END() - -