Skip to content

Commit

Permalink
Merge pull request #95 from chrisburr/diracx-integration-tests
Browse files Browse the repository at this point in the history
Support running enchanced tests against the demo instance
  • Loading branch information
chaen authored Sep 21, 2023
2 parents 1941ffa + 655edf0 commit 31674c3
Show file tree
Hide file tree
Showing 6 changed files with 112 additions and 12 deletions.
43 changes: 43 additions & 0 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,49 @@ jobs:
- name: Upload coverage report
uses: codecov/[email protected]

pytest-integration:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- uses: mamba-org/setup-micromamba@v1
with:
environment-file: environment.yml
init-shell: bash
post-cleanup: 'all'
- name: Set up environment
run: |
pip install pytest-github-actions-annotate-failures
pip install git+https://github.com/DIRACGrid/DIRAC.git@integration
pip install .
- name: Start demo
run: |
git clone https://github.com/DIRACGrid/diracx-charts.git ../diracx-charts
../diracx-charts/run_demo.sh --exit-when-done $PWD
- name: Debugging information
run: |
DIRACX_DEMO_DIR=$PWD/../diracx-charts/.demo
export KUBECONFIG=${DIRACX_DEMO_DIR}/kube.conf
export PATH=${DIRACX_DEMO_DIR}:$PATH
kubectl get pods
for pod_name in $(kubectl get pods -o json | jq -r '.items[] | .metadata.name' | grep -vE '(dex|minio|mysql|rabbitmq|opensearch)'); do
echo "${pod_name}"
kubectl describe pod/"${pod_name}" || true
for container_name in $(kubectl get pods $pod_name -o jsonpath='{.spec.initContainers[*].name} {.spec.containers[*].name}'); do
echo $pod_name $container_name
kubectl logs "${pod_name}" -c "${container_name}" || true
done
done
if [ ! -f "${DIRACX_DEMO_DIR}/.success" ]; then
cat "${DIRACX_DEMO_DIR}/.failed"
exit 1
fi
- name: Run pytest
run: |
pytest . --demo-dir ../diracx-charts/ --cov-report=xml:coverage.xml --junitxml=report.xml
- name: Upload coverage report
uses: codecov/[email protected]

mypy:
runs-on: ubuntu-latest
steps:
Expand Down
4 changes: 4 additions & 0 deletions codecov.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,8 @@ coverage:
target: 100%
informational: true

codecov:
notify:
after_n_builds: 2

comment: false
9 changes: 8 additions & 1 deletion docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ pre-commit install

### Run the test

Run the unit tests
Run the unit tests:

```bash
# In the `diracx` folder
Expand All @@ -67,6 +67,13 @@ mypy .
pre-commit run --all-files
```

Some tests require the DiracX demo instance to be running (see above) and are skipped by default.
To enable these tests pass `--demo-dir` like so:

```bash
pytest . --demo-dir ../diracx-charts/
```

### Run a local instance of diracx

This only runs the diracx server, not any dependency like external IdP.
Expand Down
19 changes: 14 additions & 5 deletions tests/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ def pytest_addoption(parser):
"--demo-dir",
type=Path,
default=None,
help="Path to a running diracx-demo directory",
help="Path to a diracx-charts directory with the demo running",
)


Expand Down Expand Up @@ -223,17 +223,26 @@ def admin_user_client(test_client, test_auth_settings):

@pytest.fixture(scope="session")
def demo_kubectl_env(request):
"""Get the dictionary of environment variables for kubectl to control the demo"""
demo_dir = request.config.getoption("--demo-dir")
if demo_dir is None:
pytest.skip("Requires a running instance of the DiracX demo")
kube_conf = demo_dir / ".demo" / "kube.conf"
demo_dir = (demo_dir / ".demo").resolve()

kube_conf = demo_dir / "kube.conf"
if not kube_conf.exists():
raise RuntimeError(f"Could not find {kube_conf}, is the demo running?")

env = {
**os.environ,
"KUBECONFIG": str(kube_conf),
"PATH": os.environ["PATH"] + ":" + str(demo_dir / ".demo"),
"PATH": f"{demo_dir}:{os.environ['PATH']}",
}
pods_result = subprocess.check_output(["kubectl", "get", "pods"], env=env)
assert pods_result

# Check that we can run kubectl
pods_result = subprocess.check_output(
["kubectl", "get", "pods"], env=env, text=True
)
assert "diracx" in pods_result

yield env
35 changes: 29 additions & 6 deletions tests/db/opensearch/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

import secrets
import socket
import subprocess
from subprocess import PIPE, Popen, check_output

import pytest

Expand Down Expand Up @@ -44,18 +44,37 @@ def index_name(self, doc_id: int) -> str:

@pytest.fixture(scope="session")
def opensearch_conn_kwargs(demo_kubectl_env):
"""Fixture which forwards a port from the diracx-demo and returns the connection kwargs."""
"""Fixture to get the OpenSearch connection kwargs.
This fixture uses kubectl to forward a port from OpenSearch service in the
diracx-demo. This port can then be used for testing DiracX against a real
OpenSearch instance.
"""
require_port_availability(OPENSEARCH_PORT)
command = [

# Ensure the pod is running
cmd = [
"kubectl",
"get",
"pod/opensearch-cluster-master-0",
"-o",
"jsonpath={.status.phase}",
]
pod_status = check_output(cmd, text=True, env=demo_kubectl_env)
if pod_status != "Running":
raise RuntimeError(f"OpenSearch pod is not running: {pod_status=}")

# Forward the actual port and wait until it has been forwarded before yielding
cmd = [
"kubectl",
"port-forward",
"service/opensearch-cluster-master",
f"{OPENSEARCH_PORT}:9200",
]
with subprocess.Popen(
command, stdout=subprocess.PIPE, universal_newlines=True, env=demo_kubectl_env
) as proc:
output_lines = []
with Popen(cmd, stdout=PIPE, stderr=PIPE, text=True, env=demo_kubectl_env) as proc:
for line in proc.stdout:
output_lines.append(line)
if line.startswith("Forwarding from"):
yield {
"hosts": f"admin:admin@localhost:{OPENSEARCH_PORT}",
Expand All @@ -64,6 +83,10 @@ def opensearch_conn_kwargs(demo_kubectl_env):
}
proc.kill()
break
else:
raise RuntimeError(
f"Could not start port forwarding with {cmd=}\n{output_lines=}"
)
proc.wait()


Expand Down
14 changes: 14 additions & 0 deletions tests/db/opensearch/test_connection.py
Original file line number Diff line number Diff line change
Expand Up @@ -78,3 +78,17 @@ async def test_connection_error_bad_password(opensearch_conn_kwargs):
}
)
await _ensure_db_unavailable(db)


async def test_sanity_checks(opensearch_conn_kwargs):
"""Check that the sanity checks are working as expected."""
db = DummyOSDB(opensearch_conn_kwargs)
# Check that the client is not available before entering the context manager
with pytest.raises(RuntimeError):
db.client.ping()

# It shouldn't be possible to enter the context manager twice
async with db.client_context():
assert db.client.ping()
with pytest.raises(AssertionError):
await db.__aenter__()

0 comments on commit 31674c3

Please sign in to comment.