From 8d13820303238bbbfa7f45b326f1c2ae8ec2bbbd Mon Sep 17 00:00:00 2001 From: "Josh V [Apple]" Date: Thu, 2 Dec 2021 17:48:38 -0800 Subject: [PATCH] Add simulated device readme. (#12508) * Add simulated device readme. * Restyled by prettier-markdown * Apply suggestions from code review * fixing word list * Apply suggestions from code review Co-authored-by: Victor Morales * Apply suggestions from code review Co-authored-by: Victor Morales * Apply suggestions from code review Co-authored-by: Victor Morales * Apply suggestions from code review Co-authored-by: Victor Morales * Apply suggestions from code review Co-authored-by: Victor Morales * Restyled by prettier-markdown Co-authored-by: Restyled.io Co-authored-by: Justin Wood Co-authored-by: Victor Morales --- .github/.wordlist.txt | 24 +++-- docs/guides/simulated_device_linux.md | 144 ++++++++++++++++++++++++++ 2 files changed, 157 insertions(+), 11 deletions(-) create mode 100644 docs/guides/simulated_device_linux.md diff --git a/.github/.wordlist.txt b/.github/.wordlist.txt index f6ced831c7bcb5..9fb6b695c40dfb 100644 --- a/.github/.wordlist.txt +++ b/.github/.wordlist.txt @@ -4,11 +4,6 @@ aarch abcdef abfb ABI -AES -DMM -ECDH -ECDSA -SHA ABIs ables accessor @@ -31,6 +26,7 @@ AdvRouterAddr AdvSendAdvert AE aef +AES algs alloc ameba @@ -286,6 +282,7 @@ dialout diffstat diffsyms dimmable +dirname dirs disambiguated discoverable @@ -297,6 +294,7 @@ DK DL DM DMG +DMM DNS Dnsmasq dnsmasqd @@ -319,6 +317,8 @@ eabi EB ECC ECD +ECDH +ECDSA EchoMessage EchoRequests EchoResponse @@ -498,15 +498,15 @@ IPv ISCAN itemName iterable +JDK jinja jlink -jre -JDK JLink JLinkExe JLinkRTTClient JN jpg +jre js json JTAG @@ -684,11 +684,11 @@ Onboarding onboardingcodes oneshot onnetwork -openjdk OnOff OnOffClusterTest OnPlatformEvent OO +openjdk OpenOCD OpenSSL OpenThread @@ -708,9 +708,9 @@ OTAImageProcessorDriver OTAProviderIpAddress OTAProviderNodeId OTAProviderSerialPort +OTARequesterImpl OTARequestor OTARequestorDriver -OTARequesterImpl OTARequestorSerialPort OTBR otcli @@ -853,8 +853,8 @@ ScriptBinding SDC SDHC SDK -sdkconfig SDK's +sdkconfig SDKs SDKTARGETSYSROOT sdl @@ -873,6 +873,7 @@ SetRequestorInstance SetUpPINCode SetupQRCode sexualized +SHA shubhamdp SIGINT SiLabs @@ -913,6 +914,7 @@ subcommand subcommands subdirectories subdirectory +subfolder submodule submodules subprocess @@ -1000,7 +1002,6 @@ unblur UNBLUR uncommissioned unfocus -userguide Unicast UniFlash unpair @@ -1012,6 +1013,7 @@ URI usbmodem USBtoUART uscif +userguide USERINTERFACE UserLabel usermod diff --git a/docs/guides/simulated_device_linux.md b/docs/guides/simulated_device_linux.md new file mode 100644 index 00000000000000..5bbd5f2b6452cf --- /dev/null +++ b/docs/guides/simulated_device_linux.md @@ -0,0 +1,144 @@ +# Simulated Device How-To (Linux) + +This document contains instructions on how to build, run, and interact with a +simulated device. All virtual accessories live in +[examples/placeholder/linux/apps](../../examples/placeholder/linux/apps). + +Each accessory needs to be hosted into a subfolder. It will be the name of the +application. For example `app1` will create a binary named `chip-app1`. + +If some parameters need to be overridden, a `CHIPProjectConfig.h` file can be +placed under an ‘include’ folder into the app folder. For example +`examples/placeholder/linux/apps/app1/include/CHIPProjectConfig.h` + +In order to generate specific tests for a given accessory, a +[examples/placeholder/linux/apps/app1/tests.js](../../examples/placeholder/linux/apps/app1/tests.js) +file can be added into the application directory. The tests listed there are the +one that will be executed once the application has been commissioned. + +Simulated Device: simulation of an application in which tests can be added. It +is defined by a ZAP config file and tests can be added with a +[YAML file](../../src/app/tests/suites/certification/Test_TC_DM_1_3_Simulated.yaml). + +### Prerequisite + +- [Building Prerequisites](./BUILDING.md#prerequisites) +- [Prepare For Building](./BUILDING.md#prepare-for-building) + +## Generating and building the default Simulated App with Script + +In order to utilize the app against a commissioner or controller, the app will +need to be specifically built. + +1. To generate the ZAP files, and build the `chip-app1` binary completing the + following steps: + + ``` + ./scripts/examples/gn_build_test_example.sh app1 + ``` + +## Build the App only + +In order to utilize the app against a commissioner or controller, the app will +need to be specifically built. + +1. To only build the `chip-app1` binary completing the following steps: + + ``` + source scripts/activate.sh + CHIP_ROOT="$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" &>/dev/null && pwd)" + GN_ARGS="chip_tests_zap_config=\"app1\"" + GN_ARGS+="chip_project_config_include_dirs=[\"$CHIP_ROOT/examples/placeholder/linux/apps/app1/include\", \"$CHIP_ROOT/config/standalone\"]" + GN_ARGS+="chip_config_network_layer_ble=false" + + gn gen --check --fail-on-unused-args --root=examples/placeholder/linux out/simulated --args="$GN_ARGS" + + ninja -C out/simulated + ``` + +## Running the app + +Now that the building is completed there is a `chip-app1` binary created. This +binary can be executed on a linux os. + +1. To generate the ZAP files, and build the `chip-app1` binary completing the + following steps: + + ``` + ./out/simulated/chip-app1 + ``` + +## Running the app with test parameter + +Now that the building is completed there is a `chip-app1` binary created. This +binary can be executed on a linux os with test commands. + +1. To generate the ZAP files, and build the `chip-app1` binary completing the + following steps: + + ``` + ./out/simulated/chip-app1 --command [TEST NAME] + ``` + +## Interacting with the simulated app + +Now that the building the app and starting it is complete, you will be able to +interact with it using chip-tool + +1. Follow the instruction to build chip-tool in the + [chip-tool readme](../../examples/chip-tool). + +2. Run this command to initiate the pairing. + ``` + ./out/debug/standalone/chip-tool pairing ethernet 0x654321 20202021 3842 [IP ADDRESS of App] 5542 + ``` +3. Run this command to complete the commissioning. + ``` + ./out/debug/standalone/chip-tool generalcommissioning commissioning-complete 0x654321 0 + ``` +4. Most tests will start at this point and now an send cluster commands with + chip-tool as follow. + + ``` + ./out/debug/standalone/chip-tool onoff on 0x654321 1 + ./out/debug/standalone/chip-tool onoff read on-off 0x654321 1 + ./out/debug/standalone/chip-tool onoff write on-time 1 0x654321 1 + ``` + + See [chip-tool readme](../../examples/chip-tool) for additional commands. + +## Adding simulated Tests via YAML + +In order to validate commissioner/controller behavior, tests need to be added to +the simulated device test framework. To achieve this, YAML files are created and +new code is generated. + +1. YAML test file are located in + [YAML folder](../../src/app/tests/suites/certification/) +2. Test names must follow a strict format dues to CI of test recognition. The + format is as follows: + - Test_TC\_[`CATEGORY ABBREVIATION`]\_[`SECTION NUMBER`]\_[`SUBSECTION + NUMBER`]\_Simulated.yaml + - `IMPORTANT`: The test name must end in Simulated with the + capital. +3. Available properties can be found in + [YAML Test Name](../../src/app/tests/suites/README.md) +4. An Additional property is as follows: + + | Name | Description | + | ---- | --------------------------------------------------------------------------- | + | wait | The command that is expected to be received on the app from the controller. | + +5. [Test_TC_DM_1_3_Simulated](../../src/app/tests/suites/certification/Test_TC_DM_1_3_Simulated.yaml) + is an example of a written test that runs on the simulated device. +6. Next, it will need to be added to + [examples/placeholder/linux/apps/app1/tests.js](../../examples/placeholder/linux/apps/app1/tests.js). + in the following array + ```javascript + const tests = ["Test_TC_DM_1_3_Simulated"]; + ``` +7. Then, the code will be generated using ZAP. Follow + [Gen Script](#generating-and-building-the-default-simulated-app-with-script) + to do so. +8. When submitting code for review, create 2 commits. One for YAML changes and + second for generated code.