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 > **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 > **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