Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Regular smoke tests #5

Merged
merged 25 commits into from
Sep 24, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
e9dc9be
ci: run the smoke tests on a schedule.
tonyandrewmeyer Aug 26, 2024
2244f83
2.9 needs to install with --classic.
tonyandrewmeyer Aug 26, 2024
885c9da
4.0 needs the beta label.
tonyandrewmeyer Aug 26, 2024
ce9912f
charmcraft needs --classic.
tonyandrewmeyer Aug 26, 2024
8fca48e
Need the actual repo to run the tests :)
tonyandrewmeyer Aug 26, 2024
05af3ff
Test on lxd and microk8s.
tonyandrewmeyer Aug 26, 2024
2f0d756
pylibjuju on 2.x and 4.x is complex, so just stick with Juju 3 for now.
tonyandrewmeyer Aug 26, 2024
c379ea4
Use the tutorial instructions for setting up microk8s.
tonyandrewmeyer Aug 26, 2024
7c686b7
Set up the cloud before Juju.
tonyandrewmeyer Aug 26, 2024
3064046
microk8s needs --classic.
tonyandrewmeyer Aug 26, 2024
cced4e6
Fix if statements.
tonyandrewmeyer Aug 26, 2024
7573ca5
Maybe the group instructions are out of date?
tonyandrewmeyer Aug 26, 2024
530553c
Simplify the microk8s install.
tonyandrewmeyer Aug 26, 2024
78aea0d
Use a pre-packaged action to get microk8s.
tonyandrewmeyer Aug 26, 2024
c4113ba
Fix the cloud name for k8s.
tonyandrewmeyer Aug 26, 2024
aa1e0f6
Run tests as root (ugh).
tonyandrewmeyer Aug 26, 2024
728789c
Install tox for root.
tonyandrewmeyer Aug 26, 2024
ad6c711
Use sudo for bootstrapping k8s.
tonyandrewmeyer Aug 26, 2024
ec417ca
Use sudo for bootstrapping k8s.
tonyandrewmeyer Aug 26, 2024
5533145
Try to get just k8s working.
tonyandrewmeyer Aug 26, 2024
e729106
LXD is required for packing.
tonyandrewmeyer Aug 26, 2024
b57a376
Pack ourselves, to work around the permission issue (and does packing…
tonyandrewmeyer Sep 4, 2024
7653ed4
The charm path needs to be absolute or Juju looks in the store.
tonyandrewmeyer Sep 4, 2024
4b57fe7
Try running against Juju 2 and 3.
tonyandrewmeyer Sep 4, 2024
49dccfd
Stick with Juju 3.5 for now.
tonyandrewmeyer Sep 4, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
68 changes: 68 additions & 0 deletions .github/workflows/smoke.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
name: ops Smoke Tests

on:
workflow_dispatch:
schedule:
- cron: '0 7 25 * *'

jobs:
test:
runs-on: ubuntu-latest

strategy:
matrix:
# pylibjuju does not currently support Juju 4.x
# The smoke tests do not yet work on Juju 2.9.
juju-version: ['3.5']
charmcraft-version: ['2.x', '3.x']
cloud: ['lxd', 'microk8s']

env:
JUJU_VERSION: "${{ matrix.juju-version }}"

steps:
# LXD is required for charmcraft to pack, even if it's not used as the
# Juju cloud.
- name: Set up LXD
uses: canonical/setup-lxd@ce8decb3609c0a03c5abd5034d02a6c145e2076f
with:
channel: 5.0/stable

- name: Set up Microk8s
if: matrix.cloud == 'microk8s'
uses: balchua/[email protected]
with:
channel: '1.26-strict/stable'
devMode: 'true'
addons: '["dns", "hostpath-storage"]'

- name: Set up Juju (classic)
if: matrix.juju-version == '2.9'
run: sudo snap install juju --classic --channel=${{ matrix.juju-version }}

- name: Set up Juju
if: matrix.juju-version != '2.9'
run: sudo snap install juju --channel=${{ matrix.juju-version }}

- name: Bootstrap Juju controller (k8s)
if: matrix.cloud == 'microk8s'
run: sg snap_microk8s -c 'juju bootstrap microk8s'

- name: Bootstrap Juju controller (lxd)
if: matrix.cloud == 'lxd'
run: juju bootstrap localhost

- name: Install charmcraft
run: sudo snap install charmcraft --channel=${{ matrix.charmcraft-version }} --classic

- name: Checkout the repository
uses: actions/checkout@v4

- name: Set up Python 3
uses: actions/setup-python@v5

- name: Install tox
run: pip install tox~=4.2

- name: Run smoke tests
run: tox -e smoke
33 changes: 32 additions & 1 deletion test/smoke/test_smoke.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,11 @@
#
# Learn more about testing at: https://juju.is/docs/sdk/testing

import grp
import logging
import os
import pathlib
import subprocess

import pytest
from pytest_operator.plugin import OpsTest
Expand Down Expand Up @@ -45,6 +49,33 @@
"""


def pack(charm_dir: pathlib.Path):
"""Pack the charm.

The pytest-operator plugin has a pack method, but it doesn't work out of the
box in GitHub actions, and there isn't really any reason that it should be
part of the plugin, so we just have a simple subprocess here.
"""
cmd = ['charmcraft', 'pack']
# We need to use `sudo` in the GitHub actions environment, just as in
# the pack test. `sg lxd -c` should work, but does not - perhaps because of
# the way we are installing LXD?
if 'lxd' not in {grp.getgrgid(g).gr_name for g in os.getgroups()}:
cmd.insert(0, 'sudo')

logger.info('Building charm with %r', cmd)
subprocess.run(cmd, cwd=charm_dir, check=True)
logger.info('Built charm')

# Move the packed charm to the charm directory.
dest_name = None
for charm in charm_dir.glob('*.charm'):
dest_name = charm_dir / charm.name
charm.rename(dest_name)
# With the way we use charmcraft, we know that there will only be one.
return dest_name.absolute()


@pytest.mark.parametrize(
'base,charmcraft_version,name',
(
Expand All @@ -61,7 +92,7 @@ async def test_smoke(ops_test: OpsTest, base: str, charmcraft_version: int, name
}[charmcraft_version].format(base=base)
with open('./test/charms/test_smoke/charmcraft.yaml', 'w') as outf:
outf.write(charmcraft_yaml)
charm = await ops_test.build_charm('./test/charms/test_smoke/')
charm = pack(pathlib.Path('./test/charms/test_smoke/'))

app = await ops_test.model.deploy(
charm, base=f'ubuntu@{base}', application_name=f'{name}-smoke'
Expand Down
3 changes: 3 additions & 0 deletions tox.ini
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,7 @@ description = Run a smoke test against a Juju controller.
allowlist_externals = juju
charmcraft
bash
passenv = JUJU_VERSION
deps =
build
coverage[toml]~=7.0
Expand All @@ -147,6 +148,8 @@ commands =
python -m build --sdist --outdir={toxinidir}/test/charms/test_smoke/
# Inject the tarball into the smoke test charm's requirements.
bash -c 'echo "./$(ls -1 ./test/charms/test_smoke/ | grep tar.gz)" > ./test/charms/test_smoke/requirements.txt'
# If a specific Juju version is set, then make sure we are using that version of pylibjuju.
bash -c 'if [ -n "$JUJU_VERSION" ]; then pip install "juju ~= $JUJU_VERSION"; fi'

# Run our smoke tests (this will build the charm, then run the tests).
pytest -v --tb native --log-cli-level=INFO -s {posargs} {toxinidir}/test/smoke/
Loading