Skip to content

Commit

Permalink
docs: add missing documentation for wokwi
Browse files Browse the repository at this point in the history
some small fixes as well
  • Loading branch information
hfudev committed Nov 7, 2023
1 parent 9c38392 commit 9d6a83d
Show file tree
Hide file tree
Showing 7 changed files with 43 additions and 22 deletions.
4 changes: 3 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ All packages are published to PyPI. Please install them via `pip`.
[![pytest-embedded-idf](https://img.shields.io/pypi/v/pytest-embedded-idf?color=green&label=pytest-embedded-idf)](https://pypi.org/project/pytest-embedded-idf/)
[![pytest-embedded-qemu](https://img.shields.io/pypi/v/pytest-embedded-qemu?color=green&label=pytest-embedded-qemu)](https://pypi.org/project/pytest-embedded-qemu/)
[![pytest-embedded-arduino](https://img.shields.io/pypi/v/pytest-embedded-arduino?color=green&label=pytest-embedded-arduino)](https://pypi.org/project/pytest-embedded-arduino/)
[![pytest-embedded-wokwi](https://img.shields.io/pypi/v/pytest-embedded-wokwi?color=green&label=pytest-embedded-wokwi)](https://pypi.org/project/pytest-embedded-wokwi/)

## Quick Example

Expand Down Expand Up @@ -59,7 +60,7 @@ The `print` line is also duplicated to console output.

## Extra Services

You can activate more services with `pytest --embedded-services service[, service]` to enable extra fixtures and functionalities.
You can activate more services with `pytest --embedded-services service[,service]` to enable extra fixtures and functionalities.
These services are provided by several optional dependencies. You can install them via `pip` as well.

Available services:
Expand All @@ -70,6 +71,7 @@ Available services:
- `jtag`: openocd/gdb utilities
- `qemu`: running test cases on QEMU instead of the real target.
- `arduino`: auto-detect more app info with [arduino](https://github.com/arduino/Arduino) specific rules, auto-flash the binary into the target.
- `wokwi`: running test cases with [Wokwi](https://wokwi.com/) instead of the real target.

## Resources

Expand Down
18 changes: 18 additions & 0 deletions docs/api.rst
Original file line number Diff line number Diff line change
Expand Up @@ -121,3 +121,21 @@ pytest-embedded-qemu
:members:
:undoc-members:
:show-inheritance:

pytest-embedded-wokwi
---------------------

.. automodule:: pytest_embedded_wokwi.wokwi_cli
:members:
:undoc-members:
:show-inheritance:

.. automodule:: pytest_embedded_wokwi.dut
:members:
:undoc-members:
:show-inheritance:

.. automodule:: pytest_embedded_wokwi.idf
:members:
:undoc-members:
:show-inheritance:
4 changes: 0 additions & 4 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,3 @@
html_logo = '_static/espressif-logo.svg'
html_static_path = ['_static']
html_theme = 'sphinx_rtd_theme'

# mermaid 10.0.0 change the CDN path
# temp workaround until sphinxcontrib-mermaid fixed it
mermaid_version = '9.4.0'
2 changes: 1 addition & 1 deletion docs/expecting.md
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ def test_expect_from_eof_current_buffer(dut):
.. note::
The pexpect process would only read from the process into the buffer when running expecting functions.
If you're expecting `pexpect.EOF` as the first statement, it would return an empty byte string
If you're expecting ``pexpect.EOF`` as the first statement, it would return an empty byte string
.. code-block:: python
Expand Down
5 changes: 3 additions & 2 deletions docs/key_concepts.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ Each test case would initialize a few fixtures. The most important fixtures are:
```{eval-rst}
.. note::
You may redirect any output to the `msg_queue` fixture by `contextlib.redirect_stdout`.
You may redirect any output to the ``msg_queue`` fixture by ``contextlib.redirect_stdout``.
.. code-block:: python
Expand Down Expand Up @@ -70,7 +70,7 @@ def test_serial_tcp(dut):

## Services

You can activate more services with `pytest --embedded-services service[, service]` to enable extra fixtures and functionalities. These services are provided by several optional dependencies. You can install them via `pip` as well.
You can activate more services with `pytest --embedded-services service[,service]` to enable extra fixtures and functionalities. These services are provided by several optional dependencies. You can install them via `pip` as well.

Available services:

Expand All @@ -80,6 +80,7 @@ Available services:
- `jtag`: openocd/gdb utilities.
- `qemu`: running test cases on QEMU instead of the real target.
- `arduino`: auto-detect more app info with [arduino](https://github.com/arduino/Arduino) specific rules, auto-flash the binary into the target.
- `wokwi`: running test cases with [Wokwi](https://wokwi.com/) instead of the real target.

## Multi DUTs

Expand Down
28 changes: 16 additions & 12 deletions docs/services.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,21 @@ Please refer to instructions under the "fixtures defined from pytest_embedded.pl

Please refer to the instructions under the "embedded" or "embedded-[SERVICE]" groups of the output of `pytest --help`.

## Services
## Dependency Graph

```{mermaid}
graph LR
pytest_embedded --> pytest_embedded_serial
pytest_embedded -->|pytest_embedded_serial_esp is an optional dependency| pytest_embedded_idf
pytest_embedded -->|pytest_embedded_idf is an optional dependency| pytest_embedded_qemu
pytest_embedded -->|pytest_embedded_serial is an optional dependency| pytest_embedded_arduino
pytest_embedded -->|pytest_embedded_idf is an optional dependency| pytest_embedded_wokwi
pytest_embedded_serial --> pytest_embedded_serial_esp
pytest_embedded_serial --> pytest_embedded_jtag
```

## Supported Services

Activate a service would enable a set of fixtures or add some extra functionalities to a few fixtures.

Expand All @@ -30,15 +44,5 @@ Activate a service would enable a set of fixtures or add some extra functionalit
```{include} ../pytest-embedded-arduino/README.md
```

## Dependency Graph

```{mermaid}
graph LR
pytest_embedded --> pytest_embedded_serial
pytest_embedded -->|pytest_embedded_serial_esp is an optional dependency| pytest_embedded_idf
pytest_embedded -->|pytest_embedded_idf is an optional dependency| pytest_embedded_qemu
pytest_embedded -->|pytest_embedded_serial is an optional dependency| pytest_embedded_arduino
pytest_embedded_serial --> pytest_embedded_serial_esp
pytest_embedded_serial --> pytest_embedded_jtag
```{include} ../pytest-embedded-wokwi/README.md
```
4 changes: 2 additions & 2 deletions pytest-embedded-wokwi/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ Wokwi supports most ESP32 targets, including: esp32, esp32s2, esp32s3, esp32c3,

Running the tests with Wokwi requires an internet connection. Your firmware is uploaded to the Wokwi server for the duration of the simulation, but it is not saved on the server. On-premises Wokwi installations are available for enterprise customers.

## Wokwi CLI installation
#### Wokwi CLI installation

The Wokwi plugin uses the [Wokwi CLI](https://github.com/wokwi/wokwi-cli) to interact with the wokwi simulation server. You can download the precompiled CLI binaries from the [releases page](https://github.com/wokwi/wokwi-cli/releases). Alternatively, on Linux or Mac OS, you can install the CLI using the following command:

Expand All @@ -20,7 +20,7 @@ And on Windows:
iwr https://wokwi.com/ci/install.ps1 -useb | iex
```

## API Tokens
#### Wokwi API Tokens

Before using this plugin, you need to create a free Wokwi account and [generate an API key](https://wokwi.com/dashboard/ci). You can then set the `WOKWI_CLI_TOKEN` environment variable to the API key.

Expand Down

0 comments on commit 9d6a83d

Please sign in to comment.