feat: partition xapi_events_all table #14
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Tutor Integration Test | |
on: | |
pull_request: | |
branches: [ main ] | |
paths-ignore: | |
- .github/** | |
- .ci/** | |
- .gitignore | |
- CHANGELOG.md | |
- setup.cfg | |
- tutoraspects/__about__.py | |
env: | |
TUTOR_ROOT: ./.ci/ | |
jobs: | |
local: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: setup python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: 3.9 | |
- name: Install python reqs | |
run: pip install -r requirements/dev.txt | |
- name: Install aspects | |
run: pip install -e . | |
- name: Tutor config save | |
run: tutor config save | |
- name: Setup Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Free Disk Space (Ubuntu) | |
uses: jlumbroso/free-disk-space@54081f138730dfa15788a46383842cd2f914a1be | |
with: | |
# this might remove tools that are actually needed, | |
# if set to "true" but frees about 6 GB | |
tool-cache: false | |
# all of these default to true, but feel free to set to | |
# "false" if necessary for your workflow | |
android: true | |
dotnet: true | |
haskell: true | |
large-packages: false | |
swap-storage: true | |
- name: Tutor build openedx | |
run: tutor images build openedx aspects aspects-superset | |
- name: Tutor start | |
run: tutor local start -d | |
- name: Tutor init | |
run: tutor local do init | |
- name: Test alembic | |
run: | | |
tutor local do alembic -c "downgrade base" | |
tutor local do alembic -c "upgrade head" | |
- name: Test DBT | |
run: tutor local do dbt -c "test" | |
- name: Load test | |
run: tutor local do load-xapi-test-data | |
- name: Import demo course | |
run: tutor local do importdemocourse | |
- name: Test commands | |
run: | | |
tutor local do dump-courses-to-clickhouse --options "--force" | |
make extract_translations | |
- name: Tutor stop | |
run: tutor local stop | |
dev: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: setup python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: 3.9 | |
- name: Install python reqs | |
run: pip install -r requirements/dev.txt | |
- name: Install aspects | |
run: pip install -e . | |
- name: Tutor config save | |
run: tutor config save | |
- name: Setup Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Free Disk Space (Ubuntu) | |
uses: jlumbroso/free-disk-space@54081f138730dfa15788a46383842cd2f914a1be | |
with: | |
# this might remove tools that are actually needed, | |
# if set to "true" but frees about 6 GB | |
tool-cache: false | |
# all of these default to true, but feel free to set to | |
# "false" if necessary for your workflow | |
android: true | |
dotnet: true | |
haskell: true | |
large-packages: false | |
swap-storage: true | |
- name: Tutor build openedx | |
run: tutor images build openedx-dev aspects aspects-superset | |
- name: Tutor start | |
run: tutor dev start -d | |
- name: Tutor init | |
run: tutor dev do init | |
- name: Test alembic | |
run: | | |
tutor dev do alembic -c "downgrade base" | |
tutor dev do alembic -c "upgrade head" | |
- name: Test DBT | |
run: tutor dev do dbt -c "test" | |
- name: Load test | |
run: tutor dev do load-xapi-test-data | |
- name: Import demo course | |
run: tutor dev do importdemocourse | |
- name: Test commands | |
run: tutor dev do dump-courses-to-clickhouse --options "--force" | |
- name: Tutor stop | |
run: tutor dev stop | |
k8s: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: setup python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: 3.9 | |
- name: Generate env | |
run: | | |
pip install -r requirements/dev.txt | |
pip install -e . | |
tutor config save | |
- name: Run Kubernetes tools | |
uses: stefanprodan/kube-tools@v1 | |
with: | |
kubectl: 1.23.0 | |
kustomize: 4.4.1 | |
helmv3: 3.7.2 | |
kubeconform: 0.4.13 | |
command: | | |
kustomize build $TUTOR_ROOT/env | kubeconform -strict -ignore-missing-schemas -kubernetes-version 1.22.0 | |
- name: Setup Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Free Disk Space (Ubuntu) | |
uses: jlumbroso/free-disk-space@54081f138730dfa15788a46383842cd2f914a1be | |
with: | |
# this might remove tools that are actually needed, | |
# if set to "true" but frees about 6 GB | |
tool-cache: false | |
# all of these default to true, but feel free to set to | |
# "false" if necessary for your workflow | |
android: true | |
dotnet: true | |
haskell: true | |
large-packages: false | |
swap-storage: true | |
- name: Tutor build openedx | |
run: tutor images build openedx aspects aspects-superset | |
- name: Create k8s Kind Cluster | |
uses: helm/[email protected] | |
- name: Mount docker image | |
run: | | |
kind get clusters | |
kind load docker-image $(tutor images printtag openedx) --name chart-testing | |
kind load docker-image $(tutor images printtag aspects) --name chart-testing | |
kind load docker-image $(tutor images printtag aspects-superset) --name chart-testing | |
- name: Setup namespace | |
run: | | |
kubectl config set-context --current --namespace=openedx | |
kubectl get pods | |
- name: Init k8s environment | |
run: | | |
tutor k8s start | |
tutor k8s do init | |
- name: Test alembic | |
run: | | |
tutor k8s do alembic -c "downgrade base" | |
tutor k8s do alembic -c "upgrade head" | |
- name: Test DBT | |
run: tutor k8s do dbt -c "test" | |
- name: Load test | |
run: tutor k8s do load-xapi-test-data | |
- name: Import demo course | |
run: tutor k8s do importdemocourse | |
- name: Test commands | |
run: tutor k8s do dump-courses-to-clickhouse --options "--force" | |
- name: Check failure logs | |
if: failure() | |
run: | | |
# Use an array to store pod names | |
pod_list=($(kubectl get pods -o jsonpath='{.items[*].metadata.name}')) | |
failed_jobs="" | |
# Loop through each pod and check for failure | |
for pod_name in "${pod_list[@]}"; do | |
# Get the pod phase/status | |
pod_phase=$(kubectl get pod "$pod_name" -o jsonpath='{.status.phase}') | |
if [[ "$pod_phase" != "Running" && "$pod_phase" != "Succeeded" ]]; then | |
# Job is not in Running or Succeeded state, consider it as failed | |
failed_jobs="$failed_jobs $pod_name" | |
# Print the logs for the failing pod | |
echo "Failure logs for pod: $pod_name" | |
kubectl logs "$pod_name" | |
fi | |
done | |
# Check if any jobs failed | |
if [ -n "$failed_jobs" ]; then | |
echo "The following jobs failed: $failed_jobs" | |
else | |
echo "All jobs succeeded." | |
fi | |
- name: Check service logs | |
if: failure() | |
run: | | |
# Use an array to store service names | |
service_list=($(kubectl get services -o jsonpath='{.items[*].metadata.name}')) | |
# Loop through each service and print logs | |
for service_name in "${service_list[@]}"; do | |
echo "Logs for service: $service_name" | |
kubectl logs "svc/$service_name" | |
echo "------------------------" | |
done | |
- name: Check jobs logs | |
if: '!cancelled()' | |
run: | | |
job_list=($(kubectl get jobs | grep job | awk '{print $1}')) | |
# Function to print logs for a pod | |
print_pod_logs() { | |
local pod_name="$1" | |
echo "Logs for pod: $pod_name" | |
kubectl logs "$pod_name" | |
echo "------------------------" | |
} | |
# Loop through each job-related pod and print logs | |
for job_name in "${job_list[@]}"; do | |
# Get the pods related to the current job | |
job_pod_list=($(kubectl get pods | grep -E "${job_name}-.*" | awk '{print $1}')) | |
for pod_name in "${job_pod_list[@]}"; do | |
print_pod_logs "$pod_name" | |
done | |
done |