131c75014Sopenharmony_ci# XTS<a name="EN-US_TOPIC_0000001126156429"></a>
231c75014Sopenharmony_ci
331c75014Sopenharmony_ci-   [Introduction](#section465982318513)
431c75014Sopenharmony_ci-   [System Types](#section125090457443)
531c75014Sopenharmony_ci-   [Directory Structure](#section161941989596)
631c75014Sopenharmony_ci-   [Constraints](#section119744591305)
731c75014Sopenharmony_ci-   [Usage Guidelines](#section137768191623)
831c75014Sopenharmony_ci-   [Test Case Development Guidelines](#section3695134065513)
931c75014Sopenharmony_ci    -   [C-based Test Case Development and Compilation \(for the Mini System\)](#section198193336544)
1031c75014Sopenharmony_ci    -   [C-based Test Case Execution \(for the Mini System\)](#section13820233175418)
1131c75014Sopenharmony_ci    -   [C++-based Test Case Development and Compilation \(for Standard and Small Systems\)](#section3822123311540)
1231c75014Sopenharmony_ci    -   [C++-based Test Case Execution \(for Standard and Small Systems\)](#section128222336544)
1331c75014Sopenharmony_ci    -   [JavaScript-based Test Case Development \(for the Standard System\)](#section159801435165220)
1431c75014Sopenharmony_ci    -   [JavaScript-based Test Case Packaging \(for the Standard System\)](#section445519106559)
1531c75014Sopenharmony_ci
1631c75014Sopenharmony_ci
1731c75014Sopenharmony_ci## Introduction<a name="section465982318513"></a>
1831c75014Sopenharmony_ci
1931c75014Sopenharmony_ciThe X test suite \(XTS\) subsystem contains a set of OpenHarmony certification test suites, including the currently supported application compatibility test suite \(ACTS\) and the device compatibility test suite \(DCTS\) that will be supported in the future.
2031c75014Sopenharmony_ci
2131c75014Sopenharmony_ciThis subsystem contains the ACTS and  **tools**  software package.
2231c75014Sopenharmony_ci
2331c75014Sopenharmony_ci-   The  **acts**  directory stores the source code and configuration files of ACTS test cases. The ACTS helps device vendors detect the software incompatibility as early as possible and ensures that the software is compatible to OpenHarmony during the entire development process.
2431c75014Sopenharmony_ci-   The  **tools**  software package stores the test case development framework related to  **acts**.
2531c75014Sopenharmony_ci
2631c75014Sopenharmony_ci## System Types<a name="section125090457443"></a>
2731c75014Sopenharmony_ci
2831c75014Sopenharmony_ciOpenHarmony supports the following system types:
2931c75014Sopenharmony_ci
3031c75014Sopenharmony_ci-   Mini system
3131c75014Sopenharmony_ci
3231c75014Sopenharmony_ci    A mini system runs on the devices whose memory is greater than or equal to 128 KiB and that are equipped with MCU processors such as ARM Cortex-M and 32-bit RISC-V. This system provides multiple lightweight network protocols and graphics frameworks, and a wide range of read/write components for the IoT bus. Typical products include connection modules, sensors, and wearables for smart home.
3331c75014Sopenharmony_ci
3431c75014Sopenharmony_ci-   Small system
3531c75014Sopenharmony_ci
3631c75014Sopenharmony_ci    A small system runs on the devices whose memory is greater than or equal to 1 MiB and that are equipped with application processors such as ARM Cortex-A. This system provides higher security capabilities, standard graphics frameworks, and video encoding and decoding capabilities. Typical products include smart home IP cameras, electronic cat eyes, and routers, and event data recorders \(EDRs\) for smart travel.
3731c75014Sopenharmony_ci
3831c75014Sopenharmony_ci-   Standard system
3931c75014Sopenharmony_ci
4031c75014Sopenharmony_ci    A standard system runs on the devices whose memory is greater than or equal to 128 MiB and that are equipped with application processors such as ARM Cortex-A. This system provides a complete application framework supporting the enhanced interaction, 3D GPU, hardware composer, diverse components, and rich animations. This system applies to high-end refrigerator displays.
4131c75014Sopenharmony_ci
4231c75014Sopenharmony_ci
4331c75014Sopenharmony_ci## Directory Structure<a name="section161941989596"></a>
4431c75014Sopenharmony_ci
4531c75014Sopenharmony_ci```
4631c75014Sopenharmony_ci/test/xts
4731c75014Sopenharmony_ci├── acts                # Test code
4831c75014Sopenharmony_ci│   └── subsystem       # Source code of subsystem test cases for the standard system
4931c75014Sopenharmony_ci│   └── subsystem_lite  # Source code of subsystems test cases for mini and small systems
5031c75014Sopenharmony_ci│   └── BUILD.gn        # Build configuration of test cases for the standard system
5131c75014Sopenharmony_ci│   └── build_lite      
5231c75014Sopenharmony_ci│       └── BUILD.gn    # Build configuration of test cases for mini and small systems
5331c75014Sopenharmony_ci└── tools               # Test tool code
5431c75014Sopenharmony_ci```
5531c75014Sopenharmony_ci
5631c75014Sopenharmony_ci## Constraints<a name="section119744591305"></a>
5731c75014Sopenharmony_ci
5831c75014Sopenharmony_ciTest cases for the mini system must be developed based on C, and those for the small system must be developed based on C++.
5931c75014Sopenharmony_ci
6031c75014Sopenharmony_ci## Usage Guidelines<a name="section137768191623"></a>
6131c75014Sopenharmony_ci
6231c75014Sopenharmony_ci**Table  1**  Test case levels
6331c75014Sopenharmony_ci
6431c75014Sopenharmony_ci<a name="table12856113719456"></a>
6531c75014Sopenharmony_ci<table><thead align="left"><tr id="row88561737114517"><th class="cellrowborder" valign="top" width="33.333333333333336%" id="mcps1.2.4.1.1"><p id="p54711456452"><a name="p54711456452"></a><a name="p54711456452"></a>Level</p>
6631c75014Sopenharmony_ci</th>
6731c75014Sopenharmony_ci<th class="cellrowborder" valign="top" width="33.283328332833285%" id="mcps1.2.4.1.2"><p id="p114834544518"><a name="p114834544518"></a><a name="p114834544518"></a>Definition</p>
6831c75014Sopenharmony_ci</th>
6931c75014Sopenharmony_ci<th class="cellrowborder" valign="top" width="33.383338333833386%" id="mcps1.2.4.1.3"><p id="p348154574518"><a name="p348154574518"></a><a name="p348154574518"></a>Scope</p>
7031c75014Sopenharmony_ci</th>
7131c75014Sopenharmony_ci</tr>
7231c75014Sopenharmony_ci</thead>
7331c75014Sopenharmony_ci<tbody><tr id="row78561137134514"><td class="cellrowborder" valign="top" width="33.333333333333336%" headers="mcps1.2.4.1.1 "><p id="p17481345124512"><a name="p17481345124512"></a><a name="p17481345124512"></a>Level0</p>
7431c75014Sopenharmony_ci</td>
7531c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.283328332833285%" headers="mcps1.2.4.1.2 "><p id="p1548945204514"><a name="p1548945204514"></a><a name="p1548945204514"></a>Smoke</p>
7631c75014Sopenharmony_ci</td>
7731c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.383338333833386%" headers="mcps1.2.4.1.3 "><p id="p174824517456"><a name="p174824517456"></a><a name="p174824517456"></a>Verifies basic functionalities of key features and basic DFX attributes with the most common input. The pass result indicates that the features are runnable.</p>
7831c75014Sopenharmony_ci</td>
7931c75014Sopenharmony_ci</tr>
8031c75014Sopenharmony_ci<tr id="row28563372451"><td class="cellrowborder" valign="top" width="33.333333333333336%" headers="mcps1.2.4.1.1 "><p id="p448445144512"><a name="p448445144512"></a><a name="p448445144512"></a>Level1</p>
8131c75014Sopenharmony_ci</td>
8231c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.283328332833285%" headers="mcps1.2.4.1.2 "><p id="p44813452452"><a name="p44813452452"></a><a name="p44813452452"></a>Basic</p>
8331c75014Sopenharmony_ci</td>
8431c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.383338333833386%" headers="mcps1.2.4.1.3 "><p id="p648184584514"><a name="p648184584514"></a><a name="p648184584514"></a>Verifies basic functionalities of key features and basic DFX attributes with common input. The pass result indicates that the features are testable.</p>
8531c75014Sopenharmony_ci</td>
8631c75014Sopenharmony_ci</tr>
8731c75014Sopenharmony_ci<tr id="row12856137204514"><td class="cellrowborder" valign="top" width="33.333333333333336%" headers="mcps1.2.4.1.1 "><p id="p164834520453"><a name="p164834520453"></a><a name="p164834520453"></a>Level2</p>
8831c75014Sopenharmony_ci</td>
8931c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.283328332833285%" headers="mcps1.2.4.1.2 "><p id="p148245184511"><a name="p148245184511"></a><a name="p148245184511"></a>Major</p>
9031c75014Sopenharmony_ci</td>
9131c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.383338333833386%" headers="mcps1.2.4.1.3 "><p id="p348945124510"><a name="p348945124510"></a><a name="p348945124510"></a>Verifies basic functionalities of key features and basic DFX attributes with common input and errors. The pass result indicates that the features are functional and ready for beta testing.</p>
9231c75014Sopenharmony_ci</td>
9331c75014Sopenharmony_ci</tr>
9431c75014Sopenharmony_ci<tr id="row48571137204514"><td class="cellrowborder" valign="top" width="33.333333333333336%" headers="mcps1.2.4.1.1 "><p id="p7481545184513"><a name="p7481545184513"></a><a name="p7481545184513"></a>Level3</p>
9531c75014Sopenharmony_ci</td>
9631c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.283328332833285%" headers="mcps1.2.4.1.2 "><p id="p1748184514455"><a name="p1748184514455"></a><a name="p1748184514455"></a>Regular</p>
9731c75014Sopenharmony_ci</td>
9831c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.383338333833386%" headers="mcps1.2.4.1.3 "><p id="p8481245104519"><a name="p8481245104519"></a><a name="p8481245104519"></a>Verifies functionalities of all key features, and all DFX attributes with common and uncommon input combinations or normal and abnormal preset conditions.</p>
9931c75014Sopenharmony_ci</td>
10031c75014Sopenharmony_ci</tr>
10131c75014Sopenharmony_ci<tr id="row14857133712451"><td class="cellrowborder" valign="top" width="33.333333333333336%" headers="mcps1.2.4.1.1 "><p id="p1248144515456"><a name="p1248144515456"></a><a name="p1248144515456"></a>Level4</p>
10231c75014Sopenharmony_ci</td>
10331c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.283328332833285%" headers="mcps1.2.4.1.2 "><p id="p94804514519"><a name="p94804514519"></a><a name="p94804514519"></a>Rare</p>
10431c75014Sopenharmony_ci</td>
10531c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.383338333833386%" headers="mcps1.2.4.1.3 "><p id="p1248445164516"><a name="p1248445164516"></a><a name="p1248445164516"></a>Verifies functionalities of key features under extremely abnormal presets and uncommon input combinations.</p>
10631c75014Sopenharmony_ci</td>
10731c75014Sopenharmony_ci</tr>
10831c75014Sopenharmony_ci</tbody>
10931c75014Sopenharmony_ci</table>
11031c75014Sopenharmony_ci
11131c75014Sopenharmony_ci**Table  2**  Test case granularities
11231c75014Sopenharmony_ci
11331c75014Sopenharmony_ci<a name="table1690733521014"></a>
11431c75014Sopenharmony_ci<table><thead align="left"><tr id="row9907143516105"><th class="cellrowborder" valign="top" width="19.591959195919593%" id="mcps1.2.4.1.1"><p id="p1141312416102"><a name="p1141312416102"></a><a name="p1141312416102"></a>Test Scale</p>
11531c75014Sopenharmony_ci</th>
11631c75014Sopenharmony_ci<th class="cellrowborder" valign="top" width="35.17351735173517%" id="mcps1.2.4.1.2"><p id="p34131416109"><a name="p34131416109"></a><a name="p34131416109"></a>Test Objects</p>
11731c75014Sopenharmony_ci</th>
11831c75014Sopenharmony_ci<th class="cellrowborder" valign="top" width="45.23452345234523%" id="mcps1.2.4.1.3"><p id="p12413141171010"><a name="p12413141171010"></a><a name="p12413141171010"></a>Test Environment</p>
11931c75014Sopenharmony_ci</th>
12031c75014Sopenharmony_ci</tr>
12131c75014Sopenharmony_ci</thead>
12231c75014Sopenharmony_ci<tbody><tr id="row2907335181017"><td class="cellrowborder" valign="top" width="19.591959195919593%" headers="mcps1.2.4.1.1 "><p id="p6414134117109"><a name="p6414134117109"></a><a name="p6414134117109"></a>LargeTest</p>
12331c75014Sopenharmony_ci</td>
12431c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="35.17351735173517%" headers="mcps1.2.4.1.2 "><p id="p20414104113101"><a name="p20414104113101"></a><a name="p20414104113101"></a>Service functionalities, all-scenario features, and mechanical power environment (MPE) and scenario-level DFX</p>
12531c75014Sopenharmony_ci</td>
12631c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="45.23452345234523%" headers="mcps1.2.4.1.3 "><p id="p5414841121013"><a name="p5414841121013"></a><a name="p5414841121013"></a>Devices close to real devices</p>
12731c75014Sopenharmony_ci</td>
12831c75014Sopenharmony_ci</tr>
12931c75014Sopenharmony_ci<tr id="row10907635131015"><td class="cellrowborder" valign="top" width="19.591959195919593%" headers="mcps1.2.4.1.1 "><p id="p19414134117104"><a name="p19414134117104"></a><a name="p19414134117104"></a>MediumTest</p>
13031c75014Sopenharmony_ci</td>
13131c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="35.17351735173517%" headers="mcps1.2.4.1.2 "><p id="p114141241141018"><a name="p114141241141018"></a><a name="p114141241141018"></a>Modules, subsystem functionalities after module integration, and DFX</p>
13231c75014Sopenharmony_ci</td>
13331c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="45.23452345234523%" headers="mcps1.2.4.1.3 "><p id="p14414941111015"><a name="p14414941111015"></a><a name="p14414941111015"></a>Single device that is actually used. You can perform message simulation, but do not mock functions.</p>
13431c75014Sopenharmony_ci</td>
13531c75014Sopenharmony_ci</tr>
13631c75014Sopenharmony_ci<tr id="row1990713353100"><td class="cellrowborder" valign="top" width="19.591959195919593%" headers="mcps1.2.4.1.1 "><p id="p641414110109"><a name="p641414110109"></a><a name="p641414110109"></a>SmallTest</p>
13731c75014Sopenharmony_ci</td>
13831c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="35.17351735173517%" headers="mcps1.2.4.1.2 "><p id="p54141541181018"><a name="p54141541181018"></a><a name="p54141541181018"></a>Modules, classes, and functions</p>
13931c75014Sopenharmony_ci</td>
14031c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="45.23452345234523%" headers="mcps1.2.4.1.3 "><p id="p1841494131013"><a name="p1841494131013"></a><a name="p1841494131013"></a>Local PC. Use a large number of mocks to replace dependencies with other modules.</p>
14131c75014Sopenharmony_ci</td>
14231c75014Sopenharmony_ci</tr>
14331c75014Sopenharmony_ci</tbody>
14431c75014Sopenharmony_ci</table>
14531c75014Sopenharmony_ci
14631c75014Sopenharmony_ci**Table  3**  Test types
14731c75014Sopenharmony_ci
14831c75014Sopenharmony_ci<a name="table18811230124619"></a>
14931c75014Sopenharmony_ci<table><thead align="left"><tr id="row48163019466"><th class="cellrowborder" valign="top" width="19.040000000000003%" id="mcps1.2.3.1.1"><p id="p1791784418465"><a name="p1791784418465"></a><a name="p1791784418465"></a>Type</p>
15031c75014Sopenharmony_ci</th>
15131c75014Sopenharmony_ci<th class="cellrowborder" valign="top" width="80.96%" id="mcps1.2.3.1.2"><p id="p2917164444614"><a name="p2917164444614"></a><a name="p2917164444614"></a>Definition</p>
15231c75014Sopenharmony_ci</th>
15331c75014Sopenharmony_ci</tr>
15431c75014Sopenharmony_ci</thead>
15531c75014Sopenharmony_ci<tbody><tr id="row682630104615"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p1091784414469"><a name="p1091784414469"></a><a name="p1091784414469"></a>Function</p>
15631c75014Sopenharmony_ci</td>
15731c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><p id="p16917344104618"><a name="p16917344104618"></a><a name="p16917344104618"></a>Tests the correctness of both service and platform functionalities provided by the tested object for end users or developers.</p>
15831c75014Sopenharmony_ci</td>
15931c75014Sopenharmony_ci</tr>
16031c75014Sopenharmony_ci<tr id="row1821930154611"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p591714474612"><a name="p591714474612"></a><a name="p591714474612"></a>Performance</p>
16131c75014Sopenharmony_ci</td>
16231c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><p id="p15917154410463"><a name="p15917154410463"></a><a name="p15917154410463"></a>Tests the processing capability of the tested object under specific preset conditions and load models. The processing capability is measured by the service volume that can be processed in a unit time, for example, call per second, frame per second, or event processing volume per second.</p>
16331c75014Sopenharmony_ci</td>
16431c75014Sopenharmony_ci</tr>
16531c75014Sopenharmony_ci<tr id="row13821030104616"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p691711440467"><a name="p691711440467"></a><a name="p691711440467"></a>Power</p>
16631c75014Sopenharmony_ci</td>
16731c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><p id="p159171544104616"><a name="p159171544104616"></a><a name="p159171544104616"></a>Tests the power consumption of the tested object in a certain period of time under specific preset conditions and load models.</p>
16831c75014Sopenharmony_ci</td>
16931c75014Sopenharmony_ci</tr>
17031c75014Sopenharmony_ci<tr id="row6821330114618"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p13917164454612"><a name="p13917164454612"></a><a name="p13917164454612"></a>Reliability</p>
17131c75014Sopenharmony_ci</td>
17231c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><p id="p11917194416465"><a name="p11917194416465"></a><a name="p11917194416465"></a>Tests the service performance of the tested object under common and uncommon input conditions, or specified service volume pressure and long-term continuous running pressure. The test covers stability, pressure handling, fault injection, and Monkey test times.</p>
17331c75014Sopenharmony_ci</td>
17431c75014Sopenharmony_ci</tr>
17531c75014Sopenharmony_ci<tr id="row11821930184612"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p1691774474618"><a name="p1691774474618"></a><a name="p1691774474618"></a>Security</p>
17631c75014Sopenharmony_ci</td>
17731c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><a name="ul112421652121513"></a><a name="ul112421652121513"></a><ul id="ul112421652121513"><li>Tests the capability of defending against security threats, including but not limited to unauthorized access, use, disclosure, damage, modification, and destruction, to ensure information confidentiality, integrity, and availability.</li><li>Tests the privacy protection capability to ensure that the collection, use, retention, disclosure, and disposal of users' private data comply with laws and regulations.</li><li>Tests the compliance with various security specifications, such as security design, security requirements, and security certification of the Ministry of Industry and Information Technology (MIIT).</li></ul>
17831c75014Sopenharmony_ci</td>
17931c75014Sopenharmony_ci</tr>
18031c75014Sopenharmony_ci<tr id="row16825307467"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p129188444462"><a name="p129188444462"></a><a name="p129188444462"></a>Global</p>
18131c75014Sopenharmony_ci</td>
18231c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><p id="p179186444465"><a name="p179186444465"></a><a name="p179186444465"></a>Tests the internationalized data and localization capabilities of the tested object, including multi-language display, various input/output habits, time formats, and regional features, such as currency, time, and culture taboos.</p>
18331c75014Sopenharmony_ci</td>
18431c75014Sopenharmony_ci</tr>
18531c75014Sopenharmony_ci<tr id="row08211308464"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p191814447465"><a name="p191814447465"></a><a name="p191814447465"></a>Compatibility</p>
18631c75014Sopenharmony_ci</td>
18731c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><a name="ul186961827111612"></a><a name="ul186961827111612"></a><ul id="ul186961827111612"><li>Tests backward compatibility of an application with its own data, the forward and backward compatibility with the system, and the compatibility with different user data, such as audio file content of the player and smart SMS messages.</li><li>Tests system backward compatibility with its own data and the compatibility of common applications in the ecosystem.</li><li>Tests software compatibility with related hardware.</li></ul>
18831c75014Sopenharmony_ci</td>
18931c75014Sopenharmony_ci</tr>
19031c75014Sopenharmony_ci<tr id="row1782730124618"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p13918144134614"><a name="p13918144134614"></a><a name="p13918144134614"></a>User</p>
19131c75014Sopenharmony_ci</td>
19231c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><p id="p1291844494611"><a name="p1291844494611"></a><a name="p1291844494611"></a>Tests user experience of the object in real user scenarios. All conclusions and comments should come from the users, which are all subjective evaluation in this case.</p>
19331c75014Sopenharmony_ci</td>
19431c75014Sopenharmony_ci</tr>
19531c75014Sopenharmony_ci<tr id="row58243024617"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p1291884474614"><a name="p1291884474614"></a><a name="p1291884474614"></a>Standard</p>
19631c75014Sopenharmony_ci</td>
19731c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><p id="p0918124424614"><a name="p0918124424614"></a><a name="p0918124424614"></a>Tests the compliance with industry and company-specific standards, protocols, and specifications. The standards here do not include any security standards that should be classified into the security test.</p>
19831c75014Sopenharmony_ci</td>
19931c75014Sopenharmony_ci</tr>
20031c75014Sopenharmony_ci<tr id="row382830124619"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p119181044164619"><a name="p119181044164619"></a><a name="p119181044164619"></a>Safety</p>
20131c75014Sopenharmony_ci</td>
20231c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><p id="p1291818443468"><a name="p1291818443468"></a><a name="p1291818443468"></a>Tests the safety property of the tested object to avoid possible hazards to personal safety, health, and the object itself.</p>
20331c75014Sopenharmony_ci</td>
20431c75014Sopenharmony_ci</tr>
20531c75014Sopenharmony_ci<tr id="row1083153014465"><td class="cellrowborder" valign="top" width="19.040000000000003%" headers="mcps1.2.3.1.1 "><p id="p39187441469"><a name="p39187441469"></a><a name="p39187441469"></a>Resilience</p>
20631c75014Sopenharmony_ci</td>
20731c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="80.96%" headers="mcps1.2.3.1.2 "><p id="p891815444462"><a name="p891815444462"></a><a name="p891815444462"></a>Tests the resilience property of the tested object to ensure that it can withstand and maintain the defined running status (including downgrading) when being attacked, and recover from and adapt defense to the attacks to approach mission assurance.</p>
20831c75014Sopenharmony_ci</td>
20931c75014Sopenharmony_ci</tr>
21031c75014Sopenharmony_ci</tbody>
21131c75014Sopenharmony_ci</table>
21231c75014Sopenharmony_ci
21331c75014Sopenharmony_ci## Test Case Development Guidelines<a name="section3695134065513"></a>
21431c75014Sopenharmony_ci
21531c75014Sopenharmony_ciYou should select the appropriate programming language and your target test framework to develop test cases.
21631c75014Sopenharmony_ci
21731c75014Sopenharmony_ci**Table  4**  Test frameworks and test case languages for different systems
21831c75014Sopenharmony_ci
21931c75014Sopenharmony_ci<a name="table4418343171415"></a>
22031c75014Sopenharmony_ci<table><thead align="left"><tr id="row34183435145"><th class="cellrowborder" valign="top" width="33.33333333333333%" id="mcps1.2.4.1.1"><p id="p941874311148"><a name="p941874311148"></a><a name="p941874311148"></a>System</p>
22131c75014Sopenharmony_ci</th>
22231c75014Sopenharmony_ci<th class="cellrowborder" valign="top" width="33.33333333333333%" id="mcps1.2.4.1.2"><p id="p1841804341413"><a name="p1841804341413"></a><a name="p1841804341413"></a>Test Framework</p>
22331c75014Sopenharmony_ci</th>
22431c75014Sopenharmony_ci<th class="cellrowborder" valign="top" width="33.33333333333333%" id="mcps1.2.4.1.3"><p id="p2418104311148"><a name="p2418104311148"></a><a name="p2418104311148"></a>Language</p>
22531c75014Sopenharmony_ci</th>
22631c75014Sopenharmony_ci</tr>
22731c75014Sopenharmony_ci</thead>
22831c75014Sopenharmony_ci<tbody><tr id="row8419164319148"><td class="cellrowborder" valign="top" width="33.33333333333333%" headers="mcps1.2.4.1.1 "><p id="p7419194312143"><a name="p7419194312143"></a><a name="p7419194312143"></a>Mini</p>
22931c75014Sopenharmony_ci</td>
23031c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.33333333333333%" headers="mcps1.2.4.1.2 "><p id="p10419124312145"><a name="p10419124312145"></a><a name="p10419124312145"></a>HCTest</p>
23131c75014Sopenharmony_ci</td>
23231c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.33333333333333%" headers="mcps1.2.4.1.3 "><p id="p11419643191410"><a name="p11419643191410"></a><a name="p11419643191410"></a>C</p>
23331c75014Sopenharmony_ci</td>
23431c75014Sopenharmony_ci</tr>
23531c75014Sopenharmony_ci<tr id="row141915438147"><td class="cellrowborder" valign="top" width="33.33333333333333%" headers="mcps1.2.4.1.1 "><p id="p441911436141"><a name="p441911436141"></a><a name="p441911436141"></a>Small</p>
23631c75014Sopenharmony_ci</td>
23731c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.33333333333333%" headers="mcps1.2.4.1.2 "><p id="p541916432142"><a name="p541916432142"></a><a name="p541916432142"></a>HCPPTest</p>
23831c75014Sopenharmony_ci</td>
23931c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.33333333333333%" headers="mcps1.2.4.1.3 "><p id="p54191643131416"><a name="p54191643131416"></a><a name="p54191643131416"></a>C++</p>
24031c75014Sopenharmony_ci</td>
24131c75014Sopenharmony_ci</tr>
24231c75014Sopenharmony_ci<tr id="row4419134341417"><td class="cellrowborder" valign="top" width="33.33333333333333%" headers="mcps1.2.4.1.1 "><p id="p341964313143"><a name="p341964313143"></a><a name="p341964313143"></a>Standard</p>
24331c75014Sopenharmony_ci</td>
24431c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.33333333333333%" headers="mcps1.2.4.1.2 "><p id="p10419443171416"><a name="p10419443171416"></a><a name="p10419443171416"></a>HJSUnit and HCPPTest</p>
24531c75014Sopenharmony_ci</td>
24631c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="33.33333333333333%" headers="mcps1.2.4.1.3 "><p id="p9419143181414"><a name="p9419143181414"></a><a name="p9419143181414"></a>JavaScript and C++</p>
24731c75014Sopenharmony_ci</td>
24831c75014Sopenharmony_ci</tr>
24931c75014Sopenharmony_ci</tbody>
25031c75014Sopenharmony_ci</table>
25131c75014Sopenharmony_ci
25231c75014Sopenharmony_ci### C-based Test Case Development and Compilation \(for the Mini System\)<a name="section198193336544"></a>
25331c75014Sopenharmony_ci
25431c75014Sopenharmony_ci**Developing test cases for the mini system**
25531c75014Sopenharmony_ci
25631c75014Sopenharmony_ciThe HCTest framework is used to support test cases developed with the C language. HCTest is enhanced and adapted based on the open-source test framework Unity.
25731c75014Sopenharmony_ci
25831c75014Sopenharmony_ci1.  Access the  **test/xts/acts**  repository where the test cases will be stored.
25931c75014Sopenharmony_ci
26031c75014Sopenharmony_ci    ```
26131c75014Sopenharmony_ci    ├── acts
26231c75014Sopenharmony_ci    │ └──subsystem_lite
26331c75014Sopenharmony_ci    │ │ └── module_hal
26431c75014Sopenharmony_ci    │ │ │ └── BUILD.gn
26531c75014Sopenharmony_ci    │ │ │ └── src
26631c75014Sopenharmony_ci    │ └──build_lite
26731c75014Sopenharmony_ci    │ │ └── BUILD.gn
26831c75014Sopenharmony_ci    ```
26931c75014Sopenharmony_ci
27031c75014Sopenharmony_ci2.  Write the test case in the  **src**  directory.
27131c75014Sopenharmony_ci
27231c75014Sopenharmony_ci    1 Import the test framework header file.
27331c75014Sopenharmony_ci
27431c75014Sopenharmony_ci    ```
27531c75014Sopenharmony_ci    #include "hctest.h"
27631c75014Sopenharmony_ci    ```
27731c75014Sopenharmony_ci
27831c75014Sopenharmony_ci    2. Use the  **LITE\_TEST\_SUIT**  macro to define names of the subsystem, module, and test suite.
27931c75014Sopenharmony_ci
28031c75014Sopenharmony_ci    ```
28131c75014Sopenharmony_ci    /**  
28231c75014Sopenharmony_ci    * @brief  Registers a test suite named IntTestSuite.
28331c75014Sopenharmony_ci    * @param  test Subsystem name
28431c75014Sopenharmony_ci    * @param  example Module name
28531c75014Sopenharmony_ci    * @param  IntTestSuite Test suite name
28631c75014Sopenharmony_ci    */
28731c75014Sopenharmony_ci    LITE_TEST_SUIT(test, example, IntTestSuite);
28831c75014Sopenharmony_ci    ```
28931c75014Sopenharmony_ci
29031c75014Sopenharmony_ci    3. Define Setup and TearDown.
29131c75014Sopenharmony_ci
29231c75014Sopenharmony_ci    Format: Test suite name+Setup, Test suite name+TearDown.
29331c75014Sopenharmony_ci
29431c75014Sopenharmony_ci    The Setup and TearDown functions must exist, but function bodies can be empty.
29531c75014Sopenharmony_ci
29631c75014Sopenharmony_ci    4. Use the  **LITE\_TEST\_CASE**  macro to write the test case.
29731c75014Sopenharmony_ci
29831c75014Sopenharmony_ci    Three parameters are involved: test suite name, test case name, and test case properties \(including type, granularity, and level\).
29931c75014Sopenharmony_ci
30031c75014Sopenharmony_ci    ```
30131c75014Sopenharmony_ci    LITE_TEST_CASE(IntTestSuite, TestCase001, Function | MediumTest | Level1) 
30231c75014Sopenharmony_ci    {  
30331c75014Sopenharmony_ci      // Do something 
30431c75014Sopenharmony_ci    };
30531c75014Sopenharmony_ci    ```
30631c75014Sopenharmony_ci
30731c75014Sopenharmony_ci    5. Use the  **RUN\_TEST\_SUITE**  macro to register the test suite.
30831c75014Sopenharmony_ci
30931c75014Sopenharmony_ci    ```
31031c75014Sopenharmony_ci    RUN_TEST_SUITE(IntTestSuite);
31131c75014Sopenharmony_ci    ```
31231c75014Sopenharmony_ci
31331c75014Sopenharmony_ci3.  Create the configuration file \(**BUILD.gn**\) of the test module.
31431c75014Sopenharmony_ci
31531c75014Sopenharmony_ci    Create a  **BUILD.gn**  \(example\) build file in each test module directory. Specify the name of the built static library and its dependent header file and library in the build file. The format is as follows:
31631c75014Sopenharmony_ci
31731c75014Sopenharmony_ci    ```
31831c75014Sopenharmony_ci    import("//test/xts/tools/lite/build/suite_lite.gni")
31931c75014Sopenharmony_ci    hctest_suite("ActsDemoTest") {
32031c75014Sopenharmony_ci        suite_name = "acts"
32131c75014Sopenharmony_ci        sources = [
32231c75014Sopenharmony_ci            "src/test_demo.c",
32331c75014Sopenharmony_ci        ]
32431c75014Sopenharmony_ci        include_dirs = [ ]
32531c75014Sopenharmony_ci        cflags = [ "-Wno-error" ]
32631c75014Sopenharmony_ci    }
32731c75014Sopenharmony_ci    ```
32831c75014Sopenharmony_ci
32931c75014Sopenharmony_ci4.  Add build options to the  **BUILD.gn**  file in the  **acts**  directory.
33031c75014Sopenharmony_ci
33131c75014Sopenharmony_ci    You need to add the test module to the  **test/xts/acts/build\_lite/BUILD.gn**  script in the  **acts**  directory.
33231c75014Sopenharmony_ci
33331c75014Sopenharmony_ci    ```
33431c75014Sopenharmony_ci    lite_component("acts") {  
33531c75014Sopenharmony_ci        ...
33631c75014Sopenharmony_ci        if(board_name == "liteos_m") {
33731c75014Sopenharmony_ci            features += [    
33831c75014Sopenharmony_ci                ...
33931c75014Sopenharmony_ci                "//xts/acts/subsystem_lite/module_hal:ActsDemoTest"
34031c75014Sopenharmony_ci            ]    
34131c75014Sopenharmony_ci        }
34231c75014Sopenharmony_ci    }
34331c75014Sopenharmony_ci    ```
34431c75014Sopenharmony_ci
34531c75014Sopenharmony_ci5.  Run build commands.
34631c75014Sopenharmony_ci
34731c75014Sopenharmony_ci    Test suites are built along with version build. The ACTS is built together with the debug version.
34831c75014Sopenharmony_ci
34931c75014Sopenharmony_ci    >![](figures/icon-note.gif) **NOTE:** 
35031c75014Sopenharmony_ci    >The ACTS build middleware is a static library, which will be linked to the image.
35131c75014Sopenharmony_ci
35231c75014Sopenharmony_ci
35331c75014Sopenharmony_ci### C-based Test Case Execution \(for the Mini System\)<a name="section13820233175418"></a>
35431c75014Sopenharmony_ci
35531c75014Sopenharmony_ci**Executing test cases for the mini system**
35631c75014Sopenharmony_ci
35731c75014Sopenharmony_ciBurn the image into the development board.
35831c75014Sopenharmony_ci
35931c75014Sopenharmony_ci**Executing the test**
36031c75014Sopenharmony_ci
36131c75014Sopenharmony_ci1.  Use a serial port tool to log in to the development board and save information about the serial port.
36231c75014Sopenharmony_ci2.  Restart the device and view serial port logs.
36331c75014Sopenharmony_ci
36431c75014Sopenharmony_ci**Analyzing the test result**
36531c75014Sopenharmony_ci
36631c75014Sopenharmony_ciView the serial port logs, whose format is as follows:
36731c75014Sopenharmony_ci
36831c75014Sopenharmony_ciThe log for each test suite starts with  **Start to run test suite:**  and ends with  **xx Tests xx Failures xx Ignored**.
36931c75014Sopenharmony_ci
37031c75014Sopenharmony_ci### C++-based Test Case Development and Compilation \(for Standard and Small Systems\)<a name="section3822123311540"></a>
37131c75014Sopenharmony_ci
37231c75014Sopenharmony_ci**Developing test cases for small-system devices**  \(For examples of the standard system, go to the  **global/i18n\_standard directory**.\)
37331c75014Sopenharmony_ci
37431c75014Sopenharmony_ciThe HCPPTest framework is enhanced and adapted based on the open-source framework Googletest.
37531c75014Sopenharmony_ci
37631c75014Sopenharmony_ci1.  Access the  **test/xts/acts**  repository where the test cases will be stored.
37731c75014Sopenharmony_ci
37831c75014Sopenharmony_ci    ```
37931c75014Sopenharmony_ci    ├── acts
38031c75014Sopenharmony_ci    │ └──subsystem_lite
38131c75014Sopenharmony_ci    │ │ └── module_posix
38231c75014Sopenharmony_ci    │ │ │ └── BUILD.gn
38331c75014Sopenharmony_ci    │ │ │ └── src
38431c75014Sopenharmony_ci    │ └──build_lite
38531c75014Sopenharmony_ci    │ │ └── BUILD.gn
38631c75014Sopenharmony_ci    ```
38731c75014Sopenharmony_ci
38831c75014Sopenharmony_ci2.  Write the test case in the  **src**  directory.
38931c75014Sopenharmony_ci
39031c75014Sopenharmony_ci    1. Import the test framework header file.
39131c75014Sopenharmony_ci
39231c75014Sopenharmony_ci    The following statement includes  **gtest.h**.
39331c75014Sopenharmony_ci
39431c75014Sopenharmony_ci    ```
39531c75014Sopenharmony_ci    #include "gtest/gtest.h"
39631c75014Sopenharmony_ci    ```
39731c75014Sopenharmony_ci
39831c75014Sopenharmony_ci    2. Define Setup and TearDown.
39931c75014Sopenharmony_ci
40031c75014Sopenharmony_ci    ```
40131c75014Sopenharmony_ci    using namespace std;
40231c75014Sopenharmony_ci    using namespace testing::ext;
40331c75014Sopenharmony_ci    class TestSuite: public testing::Test {
40431c75014Sopenharmony_ci    protected:
40531c75014Sopenharmony_ci    // Preset action of the test suite, which is executed before the first test case
40631c75014Sopenharmony_ci    static void SetUpTestCase(void){
40731c75014Sopenharmony_ci    }
40831c75014Sopenharmony_ci    // Test suite cleanup action, which is executed after the last test case
40931c75014Sopenharmony_ci    static void TearDownTestCase(void){
41031c75014Sopenharmony_ci    }
41131c75014Sopenharmony_ci    // Preset action of the test case
41231c75014Sopenharmony_ci    virtual void SetUp()
41331c75014Sopenharmony_ci    {
41431c75014Sopenharmony_ci    }
41531c75014Sopenharmony_ci    // Cleanup action of the test case
41631c75014Sopenharmony_ci    virtual void TearDown()
41731c75014Sopenharmony_ci    {
41831c75014Sopenharmony_ci    }
41931c75014Sopenharmony_ci    };
42031c75014Sopenharmony_ci    ```
42131c75014Sopenharmony_ci
42231c75014Sopenharmony_ci    3. Use the  **HWTEST**  or  **HWTEST\_F**  macro to write the test case.
42331c75014Sopenharmony_ci
42431c75014Sopenharmony_ci    **HWTEST**: definition of common test cases, including the test suite name, test case name, and case annotation.
42531c75014Sopenharmony_ci
42631c75014Sopenharmony_ci    **HWTEST\_F**: definition of SetUp and TearDown test cases, including the test suite name, test case name, and case annotation.
42731c75014Sopenharmony_ci
42831c75014Sopenharmony_ci    Three parameters are involved: test suite name, test case name, and test case properties \(including type, granularity, and level\).
42931c75014Sopenharmony_ci
43031c75014Sopenharmony_ci    ```
43131c75014Sopenharmony_ci    HWTEST_F(TestSuite, TestCase_0001, Function | MediumTest | Level1) {
43231c75014Sopenharmony_ci    // Do something
43331c75014Sopenharmony_ci    }
43431c75014Sopenharmony_ci    ```
43531c75014Sopenharmony_ci
43631c75014Sopenharmony_ci3.  Create a configuration file \(**BUILD.gn**\) of the test module.
43731c75014Sopenharmony_ci
43831c75014Sopenharmony_ci    Create a  **BUILD.gn**  build file in each test module directory. Specify the name of the built static library and its dependent header file and library in the build file. Each test module is independently built into a  **.bin**  executable file, which can be directly pushed to the development board for testing.
43931c75014Sopenharmony_ci
44031c75014Sopenharmony_ci    Example:
44131c75014Sopenharmony_ci
44231c75014Sopenharmony_ci    ```
44331c75014Sopenharmony_ci    import("//test/xts/tools/lite/build/suite_lite.gni")
44431c75014Sopenharmony_ci    hcpptest_suite("ActsDemoTest") {
44531c75014Sopenharmony_ci        suite_name = "acts"
44631c75014Sopenharmony_ci        sources = [
44731c75014Sopenharmony_ci            "src/TestDemo.cpp"
44831c75014Sopenharmony_ci        ]
44931c75014Sopenharmony_ci    
45031c75014Sopenharmony_ci        include_dirs = [
45131c75014Sopenharmony_ci            "src",
45231c75014Sopenharmony_ci            ...
45331c75014Sopenharmony_ci        ]
45431c75014Sopenharmony_ci        deps = [
45531c75014Sopenharmony_ci            ...
45631c75014Sopenharmony_ci        ]
45731c75014Sopenharmony_ci        cflags = [ "-Wno-error" ]
45831c75014Sopenharmony_ci    }
45931c75014Sopenharmony_ci    ```
46031c75014Sopenharmony_ci
46131c75014Sopenharmony_ci4.  Add build options to the  **BUILD.gn**  file in the  **acts**  directory.
46231c75014Sopenharmony_ci
46331c75014Sopenharmony_ci    Add the test module to the  **test/xts/acts/build\_lite/BUILD.gn**  script in the  **acts**  directory.
46431c75014Sopenharmony_ci
46531c75014Sopenharmony_ci    ```
46631c75014Sopenharmony_ci     lite_component("acts") {  
46731c75014Sopenharmony_ci    ...
46831c75014Sopenharmony_ci    else if(board_name == "liteos_a") {
46931c75014Sopenharmony_ci            features += [
47031c75014Sopenharmony_ci                ...
47131c75014Sopenharmony_ci                "//xts/acts/subsystem_lite/module_posix:ActsDemoTest"
47231c75014Sopenharmony_ci            ]
47331c75014Sopenharmony_ci        }
47431c75014Sopenharmony_ci    }
47531c75014Sopenharmony_ci    ```
47631c75014Sopenharmony_ci
47731c75014Sopenharmony_ci5.  Run build commands.
47831c75014Sopenharmony_ci
47931c75014Sopenharmony_ci    Test suites are built along with the version build. The ACTS is built together with the debug version.
48031c75014Sopenharmony_ci
48131c75014Sopenharmony_ci    >![](figures/icon-note.gif) **NOTE:** 
48231c75014Sopenharmony_ci    >The ACTS for the small system is independently built to an executable file \(.bin\) and archived in the  **suites\\acts**  directory of the build result.
48331c75014Sopenharmony_ci
48431c75014Sopenharmony_ci
48531c75014Sopenharmony_ci### C++-based Test Case Execution \(for Standard and Small Systems\)<a name="section128222336544"></a>
48631c75014Sopenharmony_ci
48731c75014Sopenharmony_ci**Executing test cases for the small system**
48831c75014Sopenharmony_ci
48931c75014Sopenharmony_ciCurrently, test cases are shared by the NFS and mounted to the development board for execution.
49031c75014Sopenharmony_ci
49131c75014Sopenharmony_ci**Setting up the environment**
49231c75014Sopenharmony_ci
49331c75014Sopenharmony_ci1.  Use a network cable or wireless network to connect the development board to your PC.
49431c75014Sopenharmony_ci2.  Configure the IP address, subnet mask, and gateway for the development board. Ensure that the development board and the PC are in the same network segment.
49531c75014Sopenharmony_ci3.  Install and register the NFS server on the PC and start the NFS service.
49631c75014Sopenharmony_ci4.  Run the  **mount**  command for the development board to ensure that the development board can access NFS shared files on the PC.
49731c75014Sopenharmony_ci
49831c75014Sopenharmony_ci    Format:  **mount** _NFS server IP address_**:/**_NFS shared directory_ **/**_development board directory_ **nfs**
49931c75014Sopenharmony_ci
50031c75014Sopenharmony_ci    Example:
50131c75014Sopenharmony_ci
50231c75014Sopenharmony_ci    ```
50331c75014Sopenharmony_ci    mount 192.168.1.10:/nfs /nfs nfs
50431c75014Sopenharmony_ci    ```
50531c75014Sopenharmony_ci
50631c75014Sopenharmony_ci
50731c75014Sopenharmony_ci**Executing test cases**
50831c75014Sopenharmony_ci
50931c75014Sopenharmony_ciExecute  **ActsDemoTest.bin**  to trigger test case execution, and analyze serial port logs generated after the execution is complete.
51031c75014Sopenharmony_ci
51131c75014Sopenharmony_ci### JavaScript-based Test Case Development \(for the Standard System\)<a name="section159801435165220"></a>
51231c75014Sopenharmony_ci
51331c75014Sopenharmony_ciThe HJSUnit framework is used to support automated test of OpenHarmony apps that are developed using the JavaScript language based on the JS application framework.
51431c75014Sopenharmony_ci
51531c75014Sopenharmony_ci**Basic syntax of test cases**
51631c75014Sopenharmony_ci
51731c75014Sopenharmony_ciThe test cases are developed with the JavaScript language and must meet the programming specifications of the language.
51831c75014Sopenharmony_ci
51931c75014Sopenharmony_ci**Table  5** 
52031c75014Sopenharmony_ci
52131c75014Sopenharmony_ci<a name="table13980103565212"></a>
52231c75014Sopenharmony_ci<table><thead align="left"><tr id="row1098093545218"><th class="cellrowborder" valign="top" width="17.92179217921792%" id="mcps1.2.4.1.1"><p id="p49811235135214"><a name="p49811235135214"></a><a name="p49811235135214"></a>Syntax</p>
52331c75014Sopenharmony_ci</th>
52431c75014Sopenharmony_ci<th class="cellrowborder" valign="top" width="68.88688868886888%" id="mcps1.2.4.1.2"><p id="p898183565220"><a name="p898183565220"></a><a name="p898183565220"></a>Description</p>
52531c75014Sopenharmony_ci</th>
52631c75014Sopenharmony_ci<th class="cellrowborder" valign="top" width="13.19131913191319%" id="mcps1.2.4.1.3"><p id="p17981143512526"><a name="p17981143512526"></a><a name="p17981143512526"></a>Mandatory</p>
52731c75014Sopenharmony_ci</th>
52831c75014Sopenharmony_ci</tr>
52931c75014Sopenharmony_ci</thead>
53031c75014Sopenharmony_ci<tbody><tr id="row1598183515528"><td class="cellrowborder" valign="top" width="17.92179217921792%" headers="mcps1.2.4.1.1 "><p id="p139810358527"><a name="p139810358527"></a><a name="p139810358527"></a>beforeAll</p>
53131c75014Sopenharmony_ci</td>
53231c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="68.88688868886888%" headers="mcps1.2.4.1.2 "><p id="p198111352526"><a name="p198111352526"></a><a name="p198111352526"></a>Presets a test-suite-level action executed only once before all test cases are executed. You can pass the action function as the only parameter.</p>
53331c75014Sopenharmony_ci</td>
53431c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="13.19131913191319%" headers="mcps1.2.4.1.3 "><p id="p298114355529"><a name="p298114355529"></a><a name="p298114355529"></a>No</p>
53531c75014Sopenharmony_ci</td>
53631c75014Sopenharmony_ci</tr>
53731c75014Sopenharmony_ci<tr id="row11981103512529"><td class="cellrowborder" valign="top" width="17.92179217921792%" headers="mcps1.2.4.1.1 "><p id="p20981135135215"><a name="p20981135135215"></a><a name="p20981135135215"></a>afterAll</p>
53831c75014Sopenharmony_ci</td>
53931c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="68.88688868886888%" headers="mcps1.2.4.1.2 "><p id="p39811935115217"><a name="p39811935115217"></a><a name="p39811935115217"></a>Presets a test-suite-level clear action executed only once after all test cases are executed. You can pass the clear function as the only parameter.</p>
54031c75014Sopenharmony_ci</td>
54131c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="13.19131913191319%" headers="mcps1.2.4.1.3 "><p id="p998110354527"><a name="p998110354527"></a><a name="p998110354527"></a>No</p>
54231c75014Sopenharmony_ci</td>
54331c75014Sopenharmony_ci</tr>
54431c75014Sopenharmony_ci<tr id="row1298116359526"><td class="cellrowborder" valign="top" width="17.92179217921792%" headers="mcps1.2.4.1.1 "><p id="p898112359526"><a name="p898112359526"></a><a name="p898112359526"></a>beforeEach</p>
54531c75014Sopenharmony_ci</td>
54631c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="68.88688868886888%" headers="mcps1.2.4.1.2 "><p id="p149811335175215"><a name="p149811335175215"></a><a name="p149811335175215"></a>Presets a test-case-level action executed before each test case is executed. The number of execution times is the same as the number of test cases defined by <strong id="b32523248388"><a name="b32523248388"></a><a name="b32523248388"></a>it</strong>. You can pass the action function as the only parameter.</p>
54731c75014Sopenharmony_ci</td>
54831c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="13.19131913191319%" headers="mcps1.2.4.1.3 "><p id="p13981133585212"><a name="p13981133585212"></a><a name="p13981133585212"></a>No</p>
54931c75014Sopenharmony_ci</td>
55031c75014Sopenharmony_ci</tr>
55131c75014Sopenharmony_ci<tr id="row6982435115219"><td class="cellrowborder" valign="top" width="17.92179217921792%" headers="mcps1.2.4.1.1 "><p id="p19982133517525"><a name="p19982133517525"></a><a name="p19982133517525"></a>afterEach</p>
55231c75014Sopenharmony_ci</td>
55331c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="68.88688868886888%" headers="mcps1.2.4.1.2 "><p id="p1398213575219"><a name="p1398213575219"></a><a name="p1398213575219"></a>Presets a test-case-level clear action executed after each test case is executed. The number of execution times is the same as the number of test cases defined by <strong id="b10590142313399"><a name="b10590142313399"></a><a name="b10590142313399"></a>it</strong>. You can pass the clear function as the only parameter.</p>
55431c75014Sopenharmony_ci</td>
55531c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="13.19131913191319%" headers="mcps1.2.4.1.3 "><p id="p159821535195219"><a name="p159821535195219"></a><a name="p159821535195219"></a>No</p>
55631c75014Sopenharmony_ci</td>
55731c75014Sopenharmony_ci</tr>
55831c75014Sopenharmony_ci<tr id="row16982143513521"><td class="cellrowborder" valign="top" width="17.92179217921792%" headers="mcps1.2.4.1.1 "><p id="p598203510527"><a name="p598203510527"></a><a name="p598203510527"></a>describe</p>
55931c75014Sopenharmony_ci</td>
56031c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="68.88688868886888%" headers="mcps1.2.4.1.2 "><p id="p5982123595215"><a name="p5982123595215"></a><a name="p5982123595215"></a>Defines a test suite. You can pass two parameters: test suite name and test suite function. The <strong id="b7320205019400"><a name="b7320205019400"></a><a name="b7320205019400"></a>describe</strong> statement supports nesting. You can use <strong id="b138214222410"><a name="b138214222410"></a><a name="b138214222410"></a>beforeall</strong>, <strong id="b18677102314115"><a name="b18677102314115"></a><a name="b18677102314115"></a>beforeEach</strong>, <strong id="b1353142514113"><a name="b1353142514113"></a><a name="b1353142514113"></a>afterEach</strong>, and <strong id="b131041629204111"><a name="b131041629204111"></a><a name="b131041629204111"></a>afterAll</strong> in each <strong id="b590433484116"><a name="b590433484116"></a><a name="b590433484116"></a>describe</strong> statement.</p>
56131c75014Sopenharmony_ci</td>
56231c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="13.19131913191319%" headers="mcps1.2.4.1.3 "><p id="p898217352527"><a name="p898217352527"></a><a name="p898217352527"></a>Yes</p>
56331c75014Sopenharmony_ci</td>
56431c75014Sopenharmony_ci</tr>
56531c75014Sopenharmony_ci<tr id="row6982113518526"><td class="cellrowborder" valign="top" width="17.92179217921792%" headers="mcps1.2.4.1.1 "><p id="p17982123510526"><a name="p17982123510526"></a><a name="p17982123510526"></a>it</p>
56631c75014Sopenharmony_ci</td>
56731c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="68.88688868886888%" headers="mcps1.2.4.1.2 "><p id="p598211352522"><a name="p598211352522"></a><a name="p598211352522"></a>Defines a test case. You can pass three parameters: test case name, filter parameter, and test case function.</p>
56831c75014Sopenharmony_ci<p id="p5205769588"><a name="p5205769588"></a><a name="p5205769588"></a>Usage of the filter parameter:</p>
56931c75014Sopenharmony_ci<p id="p1545919528618"><a name="p1545919528618"></a><a name="p1545919528618"></a>The value of the filter parameter is a 32-bit integer. Setting different bits to <strong id="b045919521765"><a name="b045919521765"></a><a name="b045919521765"></a>1</strong> means different configurations:</p>
57031c75014Sopenharmony_ci<a name="ul6932113319395"></a><a name="ul6932113319395"></a><ul id="ul6932113319395"><li>bit 0: whether the filter parameter takes effect. <strong id="b1193293318395"><a name="b1193293318395"></a><a name="b1193293318395"></a>1</strong> means that the test case is used for the function test and other settings of the parameter do not take effect.</li><li>Bits 0-10: test case categories</li><li>Bits 16-18: test case scales</li><li>Bits 24-28: test levels</li></ul>
57131c75014Sopenharmony_ci<p id="p7965165151011"><a name="p7965165151011"></a><a name="p7965165151011"></a><strong id="b15148755145114"><a name="b15148755145114"></a><a name="b15148755145114"></a>Test case categories</strong>: Bits 0-10 indicate FUNCTION (function test), PERFORMANCE (performance test), POWER (power consumption test), RELIABILITY (reliability test), SECURITY (security compliance test), GLOBAL (integrity test), COMPATIBILITY (compatibility test), USER (user test), STANDARD (standard test), SAFETY (security feature test), and RESILIENCE (resilience test), respectively.</p>
57231c75014Sopenharmony_ci<p id="p199651555102"><a name="p199651555102"></a><a name="p199651555102"></a><strong id="b135908568519"><a name="b135908568519"></a><a name="b135908568519"></a>Test case scales</strong>: Bits 16-18 indicate SMALL (small-scale test), MEDIUM (medium-scale test), and LARGE (large-scale test), respectively.</p>
57331c75014Sopenharmony_ci<p id="p296545151020"><a name="p296545151020"></a><a name="p296545151020"></a><strong id="b12181058125111"><a name="b12181058125111"></a><a name="b12181058125111"></a>Test levels</strong>: Bits 24-28 indicate LEVEL0 (level-0 test), LEVEL1 (level-1 test), LEVEL2 (level-2 test), LEVEL3 (level-3 test), and LEVEL4 (level-4 test), respectively.</p>
57431c75014Sopenharmony_ci</td>
57531c75014Sopenharmony_ci<td class="cellrowborder" valign="top" width="13.19131913191319%" headers="mcps1.2.4.1.3 "><p id="p17601752115716"><a name="p17601752115716"></a><a name="p17601752115716"></a>Yes</p>
57631c75014Sopenharmony_ci</td>
57731c75014Sopenharmony_ci</tr>
57831c75014Sopenharmony_ci</tbody>
57931c75014Sopenharmony_ci</table>
58031c75014Sopenharmony_ci
58131c75014Sopenharmony_ciUse the standard syntax of Jasmine to write test cases. The ES6 specification is supported.
58231c75014Sopenharmony_ci
58331c75014Sopenharmony_ci1.  Store the test cases in the  **entry/src/main/js/test**  directory, whose structure is as follows:
58431c75014Sopenharmony_ci
58531c75014Sopenharmony_ci    ```
58631c75014Sopenharmony_ci    ├── BUILD.gn   
58731c75014Sopenharmony_ci    │ └──entry
58831c75014Sopenharmony_ci    │ │ └──src
58931c75014Sopenharmony_ci    │ │ │ └──main
59031c75014Sopenharmony_ci    │ │ │ │ └──js
59131c75014Sopenharmony_ci    │ │ │ │ │ └──default               
59231c75014Sopenharmony_ci    │ │ │ │ │ │ └──pages
59331c75014Sopenharmony_ci    │ │ │ │ │ │ │ └──index             
59431c75014Sopenharmony_ci    │ │ │ │ │ │ │ │ └──index.js        # Entry file
59531c75014Sopenharmony_ci     │ │ │ │ │ └──test                  # Test code
59631c75014Sopenharmony_ci    │ │ │ └── resources                # HAP resources
59731c75014Sopenharmony_ci    │ │ │ └── config.json              # HAP configuration file
59831c75014Sopenharmony_ci    ```
59931c75014Sopenharmony_ci
60031c75014Sopenharmony_ci2.  Start the JS test framework and load test cases. The following is an example for  **index.js**.
60131c75014Sopenharmony_ci
60231c75014Sopenharmony_ci    ```
60331c75014Sopenharmony_ci    // Start the JS test framework and load test cases.
60431c75014Sopenharmony_ci    import {Core, ExpectExtend} from 'deccjsunit/index'
60531c75014Sopenharmony_ci    
60631c75014Sopenharmony_ci    export default {
60731c75014Sopenharmony_ci        data: {
60831c75014Sopenharmony_ci            title: ""
60931c75014Sopenharmony_ci        },
61031c75014Sopenharmony_ci        onInit() {
61131c75014Sopenharmony_ci            this.title = this.$t('strings.world');
61231c75014Sopenharmony_ci        },
61331c75014Sopenharmony_ci        onShow() {
61431c75014Sopenharmony_ci            console.info('onShow finish')
61531c75014Sopenharmony_ci            const core = Core.getInstance()
61631c75014Sopenharmony_ci            const expectExtend = new ExpectExtend({
61731c75014Sopenharmony_ci                'id': 'extend'
61831c75014Sopenharmony_ci            })
61931c75014Sopenharmony_ci            core.addService('expect', expectExtend)
62031c75014Sopenharmony_ci            core.init()
62131c75014Sopenharmony_ci            const configService = core.getDefaultService('config')
62231c75014Sopenharmony_ci            configService.setConfig(this)
62331c75014Sopenharmony_ci            require('../../../test/List.test')
62431c75014Sopenharmony_ci            core.execute()
62531c75014Sopenharmony_ci        },
62631c75014Sopenharmony_ci        onReady() {
62731c75014Sopenharmony_ci        },
62831c75014Sopenharmony_ci    }
62931c75014Sopenharmony_ci    ```
63031c75014Sopenharmony_ci
63131c75014Sopenharmony_ci3.  Write a unit test case by referring to the following example:
63231c75014Sopenharmony_ci
63331c75014Sopenharmony_ci    ```
63431c75014Sopenharmony_ci    // Use HJSUnit to perform the unit test.
63531c75014Sopenharmony_ci    describe('appInfoTest', function () {    
63631c75014Sopenharmony_ci        it('app_info_test_001', 0, function () {
63731c75014Sopenharmony_ci            var info = app.getInfo()
63831c75014Sopenharmony_ci            expect(info.versionName).assertEqual('1.0')
63931c75014Sopenharmony_ci            expect(info.versionCode).assertEqual('3')
64031c75014Sopenharmony_ci        })
64131c75014Sopenharmony_ci    }) 
64231c75014Sopenharmony_ci    ```
64331c75014Sopenharmony_ci
64431c75014Sopenharmony_ci
64531c75014Sopenharmony_ci### JavaScript-based Test Case Packaging \(for the Standard System\)<a name="section445519106559"></a>
64631c75014Sopenharmony_ci
64731c75014Sopenharmony_ciFor details about how to build a HAP, see the JS application development guide of the standard system  [Building and Creating HAPs](https://developer.harmonyos.com/en/docs/documentation/doc-guides/build_overview-0000001055075201).
64831c75014Sopenharmony_ci
649