name: Constellation verify description: "Verify a Constellation cluster." inputs: osImage: description: "The OS image used in the cluster." required: true cloudProvider: description: "The cloud provider used in the cluster." required: true kubeconfig: description: "The kubeconfig file for the cluster." required: true runs: using: "composite" steps: - name: Expand version path id: expand-version uses: ./.github/actions/shortname with: shortname: ${{ inputs.osImage }} - name: Constellation fetch measurements shell: bash run: | if [[ ${{ steps.expand-version.outputs.stream }} == "debug" ]] then constellation config fetch-measurements --insecure else constellation config fetch-measurements fi - name: Constellation verify shell: bash run: constellation verify --cluster-id $(jq -r ".clusterID" constellation-id.json) --force - name: Verify all nodes shell: bash env: KUBECONFIG: ${{ inputs.kubeconfig }} run: | nodes=$(kubectl get nodes -o json | jq -r ".items[].metadata.name") for node in $nodes ; do verificationPod=$(kubectl get pods --field-selector spec.nodeName=${node} -n kube-system | grep "verification-service" | cut -d' ' -f1) mapfile -t verificationPod <<< "$verificationPod" if [[ ${#verificationPod[@]} -ne 1 ]]; then echo "Expected 1 verification pod for node ${node}, found ${#verificationPodArray[@]}" exit 1 fi echo "Verifying pod ${pod} on node ${node}" kubectl wait -n kube-system "pod/${verificationPod}" --for=condition=ready --timeout=5m kubectl port-forward -n kube-system "pods/${verificationPod}" 9090:9090 & forwarderPID=$! sleep 5 constellation verify --cluster-id $(jq -r ".clusterID" constellation-id.json) --force --node-endpoint localhost:9090 kill $forwarderPID done