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

Documentation #9

Merged
merged 2 commits into from
Oct 11, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
2 changes: 2 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -1 +1,3 @@
# Contribute to the test-operator

We accept changes proposed as pull requests.
79 changes: 7 additions & 72 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,80 +1,15 @@
# test-operator
// TODO(user): Add simple overview of use/purpose
This is a test operator that automates testing of an OpenStack deployment
running on a Kubernetes cluster. The operator runs
[Tempest](https://opendev.org/openstack/tempest) tests.

## Description
// TODO(user): An in-depth paragraph about your project and overview of use

## Getting Started
You’ll need a Kubernetes cluster to run against. You can use [KIND](https://sigs.k8s.io/kind) to get a local cluster for testing, or run against a remote cluster.
**Note:** Your controller will automatically use the current context in your kubeconfig file (i.e. whatever cluster `kubectl cluster-info` shows).
First, you will need an OpenStack Platform running on OpenShift. See, the
[ci-framework documentation](https://ci-framework.readthedocs.io/en/latest/)
to get you started. It will get you through the installation of such environment.

### Running on the cluster
1. Install Instances of Custom Resources:

```sh
kubectl apply -f config/samples/
```

2. Build and push your image to the location specified by `IMG`:

```sh
make docker-build docker-push IMG=<some-registry>/test-operator:tag
```

3. Deploy the controller to the cluster with the image specified by `IMG`:

```sh
make deploy IMG=<some-registry>/test-operator:tag
```

### Uninstall CRDs
To delete the CRDs from the cluster:

```sh
make uninstall
```

### Undeploy controller
UnDeploy the controller to the cluster:

```sh
make undeploy
```

## Contributing
// TODO(user): Add detailed information on how you would like others to contribute to this project

### How it works
This project aims to follow the Kubernetes [Operator pattern](https://kubernetes.io/docs/concepts/extend-kubernetes/operator/)

It uses [Controllers](https://kubernetes.io/docs/concepts/architecture/controller/)
which provides a reconcile function responsible for synchronizing resources untile the desired state is reached on the cluster

### Test It Out
1. Install the CRDs into the cluster:

```sh
make install
```

2. Run your controller (this will run in the foreground, so switch to a new terminal if you want to leave it running):

```sh
make run
```

**NOTE:** You can also run this in one step by running: `make install run`

### Modifying the API definitions
If you are editing the API definitions, generate the manifests such as CRs or CRDs using:

```sh
make manifests
```

**NOTE:** Run `make --help` for more information on all potential `make` targets

More information can be found via the [Kubebuilder Documentation](https://book.kubebuilder.io/introduction.html)
Then proceed to our [documentation](https://openstack-k8s-operators.github.io/test-operator/).

## License

Expand Down
2 changes: 1 addition & 1 deletion docs/requirements.txt
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
ansible-core>=2.14.6
sphinx>=6.2.1 # BSD
sphinx-autobuild>=2021.3.1
sphinx_rtd_theme>=1.2.2
sphinx-material
doc8>=0.8.1 # Apache-2.0
sphinxemoji
myst-parser
96 changes: 0 additions & 96 deletions docs/source/Makefile

This file was deleted.

22 changes: 20 additions & 2 deletions docs/source/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -83,14 +83,32 @@

# The theme to use for HTML and HTML Help pages. See the documentation for
# a list of builtin themes.
# html_theme = "sphinx_rtd_theme"
# html_logo = "images/logo_cifmw_200.png"
html_theme = "sphinx_material"

html_show_sourcelink = True
html_sidebars = {
"**": ["globaltoc.html", "localtoc.html"]
}

# Theme options are theme-specific and customize the look and feel of a theme
# further. For a list of options available for each theme, see the
# documentation.
#
# html_theme_options = {}
html_theme_options = {
"base_url": "https://github.com/openstack-k8s-operators/test-operator/",
"repo_url": "https://github.com/openstack-k8s-operators/test-operator/",
"nav_title": "test-operator",
"repo_name": "test-operator",
"repo_type": "github",
"globaltoc_depth": 2,
"color_primary": "blue-grey",
"color_accent": "cyan",
"touch_icon": "images/openstack-logo.png",
"theme_color": "#2196f3",
"master_doc": False,
"table_classes": ["plain"],
}

# -- Options for HTMLHelp output ------------------------------------------

Expand Down
55 changes: 55 additions & 0 deletions docs/source/guide.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
User Guide
==========

This guide is a starting point for configuring and running the `test-operator`.

Installation
------------

.. code-block:: bash

make install
kopecmartin marked this conversation as resolved.
Show resolved Hide resolved

Execution
---------
Execute the following command to run the operator. Note, that after running the
following command you will need to switch to another terminal unless you run it
in the background.

.. code-block:: bash

make run

.. note::
You can run this step together with the installation at once by running: ``make install run``

Then apply a tempest resource definition, e.g. the default one:

.. literalinclude:: ../../config/samples/test_v1beta1_tempest.yaml
:language: yaml

kopecmartin marked this conversation as resolved.
Show resolved Hide resolved
.. code-block:: bash

oc apply -f config/samples/test_v1beta1_tempest.yaml

After that, verify that a pod was created with:

.. code-block:: bash

oc get pods | grep tempest

You should see a pod with a name like `tempest-tests-xxxxx`.

To see the console output of the execution run the following:

.. code-block:: bash

oc logs <name of the pod>

Custom Tempest Configuration
----------------------------
This is TBA.

Getting logs
------------
This is TBA.
24 changes: 24 additions & 0 deletions docs/source/images.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
Test Images
===========

The `test-operator` uses images that are built and defined in
`TCIB (The Container Image Build) <https://github.com/openstack-k8s-operators/tcib>`_.
The built images are published to `quay.io <https://quay.io/>`_.

.. note::
You can use the images to run a container or a pod on your own, without
running the test-operator, see `Run Tempest in a Pod <./tempest_pod.html>`_
or `Run Tempest via Podman <./tempest_podman.html>`_.

To find all tempest images, go to
`podified-master-centos9 organization <https://quay.io/organization/podified-master-centos9>`_
and filter for *tempest* results.

Currently, there are the following tempest images:

* `openstack-tempest <https://quay.io/podified-antelope-centos9/openstack-tempest>`_
* `openstack-tempest-extras <https://quay.io/podified-antelope-centos9/openstack-tempest-extras>`_

`test-operator` runs, for now, only the following test images:

* openstack-tempest
33 changes: 23 additions & 10 deletions docs/source/index.rst
Original file line number Diff line number Diff line change
@@ -1,27 +1,40 @@
.. documentation master file

=============
test-operator
=============
===============================
Documentation for test-operator
===============================

Welcome to the documentation for test-operator. This documentation is designed
to help you get up and running with our project as quickly and smoothly as
possible.

Overview
========
.. toctree::
:maxdepth: 1
:caption: Overview

readme.md

Configuration Guide
===================
.. toctree::
:maxdepth: 1
:caption: For Contributors

contributing.md
prerequisites.rst
images.rst
guide.rst

Debugging
=========
.. toctree::
:maxdepth: 1

Indices and tables
==================
tempest_pod.rst
tempest_podman.rst

* :ref:`genindex`
* :ref:`search`
For Contributors
================
.. toctree::
:maxdepth: 1

contributing.md
21 changes: 21 additions & 0 deletions docs/source/prerequisites.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
Prerequisites
=============

First, you will need an OpenStack Platform running on OpenShift. See, the
`ci-framework documentation <https://ci-framework.readthedocs.io/en/latest/>`_
to get you started. It will get you through the installation of such environment.

E.g. if you want to install OpenStack Platform running on OpenShift on your
own hardware, follow `the steps in this doc <https://ci-framework.readthedocs.io/en/latest/quickstart/04_non-virt.html>`_.

After the installations is completed, you can source the credentials to the
environment as follows:

.. code-block:: bash

eval $(${HOME}/ci-framework-data/bin/crc oc-env)
export KUBECONFIG="${HOME}/.crc/machines/crc/kubeconfig"
oc login -u kubeadmin -p 12345678 https://api.crc.testing:6443

.. note::
12345678 is a default password set by ci-framework
7 changes: 7 additions & 0 deletions docs/source/samples/tempest-config.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
apiVersion: v1
kind: ConfigMap
metadata:
name: my-tempest-data
data:
include.txt: |
tempest.api.identity.v3
Loading
Loading