From b02b8415f0f72729ef50848b320b10aa7cb3ac63 Mon Sep 17 00:00:00 2001 From: Mikolaj Izdebski Date: Wed, 11 Dec 2024 09:00:18 +0100 Subject: [PATCH] Sync tests from Fedora --- .fmf/version | 1 + ci.fmf | 1 + gating.yaml | 4 +- plans/javapackages.fmf | 7 ++++ plans/smoke.fmf | 5 +++ tests/Sanity/smoke/main.fmf | 9 +++++ tests/Sanity/smoke/runtest.sh | 70 +++++++++++++++++++++++++++++++++++ tests/main.fmf | 4 ++ 8 files changed, 99 insertions(+), 2 deletions(-) create mode 100644 .fmf/version create mode 100644 ci.fmf create mode 100644 plans/javapackages.fmf create mode 100644 plans/smoke.fmf create mode 100644 tests/Sanity/smoke/main.fmf create mode 100755 tests/Sanity/smoke/runtest.sh create mode 100644 tests/main.fmf diff --git a/.fmf/version b/.fmf/version new file mode 100644 index 0000000..d00491f --- /dev/null +++ b/.fmf/version @@ -0,0 +1 @@ +1 diff --git a/ci.fmf b/ci.fmf new file mode 100644 index 0000000..c5aa0e0 --- /dev/null +++ b/ci.fmf @@ -0,0 +1 @@ +resultsdb-testcase: separate diff --git a/gating.yaml b/gating.yaml index d6b7694..7f72400 100644 --- a/gating.yaml +++ b/gating.yaml @@ -4,5 +4,5 @@ product_versions: decision_contexts: - osci_compose_gate rules: - # https://docs.engineering.redhat.com/display/RHELPLAN/Maven+Bootstrap+manual+gating+test - - !PassingTestCaseRule {test_case_name: manual.sst_cs_apps.maven.bootstrap} + - !PassingTestCaseRule {test_case_name: osci.brew-build./plans/smoke.functional} + - !PassingTestCaseRule {test_case_name: osci.brew-build./plans/javapackages.functional} diff --git a/plans/javapackages.fmf b/plans/javapackages.fmf new file mode 100644 index 0000000..8ba3510 --- /dev/null +++ b/plans/javapackages.fmf @@ -0,0 +1,7 @@ +summary: Run javapackages-specific tests +discover: + how: fmf + url: https://src.fedoraproject.org/tests/javapackages + ref: c9s +execute: + how: tmt diff --git a/plans/smoke.fmf b/plans/smoke.fmf new file mode 100644 index 0000000..a1e7bfd --- /dev/null +++ b/plans/smoke.fmf @@ -0,0 +1,5 @@ +summary: Basic smoke test +discover: + how: fmf +execute: + how: tmt diff --git a/tests/Sanity/smoke/main.fmf b/tests/Sanity/smoke/main.fmf new file mode 100644 index 0000000..2a35e02 --- /dev/null +++ b/tests/Sanity/smoke/main.fmf @@ -0,0 +1,9 @@ +summary: XMvn smoke test +description: | + Test basic functionality of XMvn. +require: + - xmvn + - xmvn-minimal + - xmvn-tools + - maven-dependency-plugin + - junit diff --git a/tests/Sanity/smoke/runtest.sh b/tests/Sanity/smoke/runtest.sh new file mode 100755 index 0000000..dda3989 --- /dev/null +++ b/tests/Sanity/smoke/runtest.sh @@ -0,0 +1,70 @@ +#!/bin/bash +# Author: Mikolaj Izdebski +. /usr/share/beakerlib/beakerlib.sh + +rlJournalStart + + rlPhaseStartTest "check for presence of XMvn commands" + rlAssertRpm xmvn + rlAssertRpm xmvn-minimal + rlAssertRpm xmvn-tools + rlAssertBinaryOrigin xmvn xmvn-minimal + rlAssertBinaryOrigin xmvn-install xmvn-tools + rlAssertBinaryOrigin xmvn-resolve xmvn-tools + rlAssertBinaryOrigin xmvn-subst xmvn-tools + rlPhaseEnd + + rlPhaseStartTest "display xmvn version" + rlRun -s "xmvn --version" + rlAssertGrep "^Apache Maven " $rlRun_LOG + rlAssertGrep "^Maven home: " $rlRun_LOG + rlAssertGrep "^Java version:" $rlRun_LOG + rlPhaseEnd + + rlPhaseStartTest "display xmvn help" + rlRun -s "xmvn --help" + rlAssertGrep "Comma-delimited list of" $rlRun_LOG + rlPhaseEnd + + rlPhaseStartTest "display xmvn-install help" + rlRun -s "xmvn-install --help" + rlAssertGrep "^xmvn-install: Install artifacts" $rlRun_LOG + rlAssertGrep "^Usage: xmvn-install" $rlRun_LOG + rlPhaseEnd + + rlPhaseStartTest "display xmvn-resolve help" + rlRun -s "xmvn-resolve --help" + rlAssertGrep "^xmvn-resolve: Resolve artifacts from system repository" $rlRun_LOG + rlAssertGrep "^Usage: xmvn-resolve" $rlRun_LOG + rlPhaseEnd + + rlPhaseStartTest "display xmvn-subst help" + rlRun -s "xmvn-subst --help" + rlAssertGrep "^xmvn-subst: Substitute artifact files with symbolic links" $rlRun_LOG + rlAssertGrep "^Usage: xmvn-subst" $rlRun_LOG + rlPhaseEnd + + rlPhaseStartTest "resolve local artifact" + rlRun "rm -rf $HOME/.m2/repository/junit/junit/4.12/" + rlAssertNotExists $HOME/.m2/repository/junit/junit/4.12/junit-4.12.jar + rlRun -s "xmvn -Dxmvn.debug=1 -B dependency:get -Dartifact=junit:junit:4.12" + rlAssertGrep "BUILD SUCCESS" $rlRun_LOG + rlAssertGrep "Resolving junit:junit:jar:4.12 with transitive dependencies" $rlRun_LOG + rlAssertGrep "Trying to resolve artifact junit:junit:jar:4.12" $rlRun_LOG + rlAssertGrep "Artifact junit:junit:jar:4.12 was resolved to /usr/share/java/" $rlRun_LOG + rlAssertNotExists $HOME/.m2/repository/junit/junit/4.12/junit-4.12.jar + rlPhaseEnd + + rlPhaseStartTest "download remote artifact" + rlRun "rm -rf $HOME/.m2/repository/turbine/turbine/2.1/" + rlAssertNotExists $HOME/.m2/repository/turbine/turbine/2.1/turbine-2.1.jar + rlRun -s "xmvn -Dxmvn.debug=1 -B dependency:get -Dartifact=turbine:turbine:2.1" + rlAssertGrep "BUILD SUCCESS" $rlRun_LOG + rlAssertGrep "Resolving turbine:turbine:jar:2.1 with transitive dependencies" $rlRun_LOG + rlAssertGrep "Trying to resolve artifact turbine:turbine:jar:2.1" $rlRun_LOG + rlAssertGrep "Failed to resolve artifact: turbine:turbine:jar:2.1" $rlRun_LOG + rlAssertExists $HOME/.m2/repository/turbine/turbine/2.1/turbine-2.1.jar + rlPhaseEnd + +rlJournalEnd +rlJournalPrintText diff --git a/tests/main.fmf b/tests/main.fmf new file mode 100644 index 0000000..9e2ea10 --- /dev/null +++ b/tests/main.fmf @@ -0,0 +1,4 @@ +contact: Mikolaj Izdebski +framework: beakerlib +test: ./runtest.sh +tier: 1