The [Ability Privilege Level (APL)](accesstoken-overview.md#app-apls) of an application can be **normal**, **system_basic**, or **system_core**. The default APL is **normal**. The [permission types](accesstoken-overview.md#permission-types) include **system_grant** and **user_grant**. For details about the permissions for apps, see the [Application Permission List](permission-list.md).
The [Ability Privilege Level (APL)](accesstoken-overview.md#app-apls) of an application can be **normal**, **system_basic**, or **system_core**. The default APL is **normal**. The [permission types](accesstoken-overview.md#permission-types) include **system_grant** and **user_grant**. For details about the permissions for applications, see the [Application Permission List](permission-list.md).
This document describes the following operations:
This document describes:
-[Declaring Permissions in the Configuration File](#declaring-permissions-in-the-configuration-file)
-[Declaring Permissions in the Configuration File](#declaring-permissions-in-the-configuration-file)
-[Declaring Permissions in the ACL](#declaring-permissions-in-the-acl)
-[Declaring Permissions in the ACL](#declaring-permissions-in-the-acl)
...
@@ -119,23 +119,22 @@ For example, if an application needs to access audio files of a user and capture
...
@@ -119,23 +119,22 @@ For example, if an application needs to access audio files of a user and capture
If an application needs to access user privacy information or use system abilities, for example, accessing location or calendar information or using the camera to take photos or record videos, it must request the permission from users. A permission verification is performed first to determine whether the current invoker has the corresponding permission. If the application has not obtained that permission, a dialog box will be displayed to request user authorization. The following figure shows an example.
If an application needs to access user privacy information or use system abilities, for example, accessing location or calendar information or using the camera to take photos or record videos, it must request the permission from users. A permission verification is performed first to determine whether the current invoker has the corresponding permission. If the application has not obtained that permission, a dialog box will be displayed to request user authorization. The following figure shows an example.
> **NOTE**<br>Each time before an API protected by a permission is accessed, the [**requestPermissionsFromUser()**](../reference/apis/js-apis-abilityAccessCtrl.md#requestpermissionsfromuser9) API will be called to request user authorization. After a permission is dynamically granted, the user may revoke the permission. Therefore, the previously granted authorization status cannot be persistent.
> **NOTE**<br>Each time before an API protected by a permission is accessed, [**requestPermissionsFromUser()**](../reference/apis/js-apis-abilityAccessCtrl.md#requestpermissionsfromuser9) will be called to request user authorization. After a permission is dynamically granted, the user may revoke the permission. Therefore, the previously granted authorization status cannot be persistent.
### Stage Model
### Stage Model
Example: Request the permission to read calendar information for an app.
Example: Request the permission for an application to access calendar information.
1. Apply for the **ohos.permission.READ_CALENDAR** permission. For details, see [Declaring Permissions in the Configuration File](#declaring-permissions-in-the-configuration-file).
1. Apply for the **ohos.permission.READ_CALENDAR** permission. For details, see [Declaring Permissions in the Configuration File](#declaring-permissions-in-the-configuration-file).
2. Call [**requestPermissionsFromUser()**](../reference/apis/js-apis-abilityAccessCtrl.md#requestpermissionsfromuser9) in the **onWindowStageCreate()** callback of the UIAbility to dynamically apply for the permission, or request user authorization on the UI based on service requirements. The return value of [requestPermissionsFromUser()](../reference/apis/js-apis-abilityAccessCtrl.md#requestpermissionsfromuser9) indicates whether the app has the target permission. If yes, the target API can be called normally.
2. Call [**requestPermissionsFromUser()**](../reference/apis/js-apis-abilityAccessCtrl.md#requestpermissionsfromuser9) in the **onWindowStageCreate()** callback of the UIAbility to dynamically apply for the permission, or request user authorization on the UI based on service requirements. The return value of [requestPermissionsFromUser()](../reference/apis/js-apis-abilityAccessCtrl.md#requestpermissionsfromuser9) indicates whether the application has the target permission. If yes, the target API can be called normally.
By default, the **user_grant** permissions must be dynamically authorized by the user through a dialog box. However, for pre-installed apps, you can pre-authroize the permissions, for example, the **ohos.permission.MICROPHONE** permission, in the [**install_list_permission.json**](https://gitee.com/openharmony/vendor_hihope/blob/master/rk3568/preinstall-config/install_list_permissions.json) file to prevent the user authorization dialog box from being displayed. The **install_list_permissions.json** file is in the **/system/etc/app/** directory on a device. When the device is started, the **install_list_permissions.json** file is loaded. When the application is installed, the **user_grant** permissions in the file are granted. The **install_list_permissions.json** file contains the following fields:
By default, the **user_grant** permissions must be dynamically authorized by the user through a dialog box. However, for pre-installed applications, you can pre-authorize the permissions, for example, the **ohos.permission.MICROPHONE** permission for camera applications, in the [**install_list_permission.json**] file to prevent the user authorization dialog box from being displayed. The [**install_list_permissions.json** file](https://gitee.com/openharmony/vendor_hihope/blob/master/rk3568/preinstall-config/install_list_permissions.json) is in the **/system/etc/app/** directory on a device. When the device is started, the **install_list_permissions.json** file is loaded. When the application is installed, the **user_grant** permissions in the file are granted. The **install_list_permissions.json** file contains the following fields:
-**bundleName**: bundle name of the application.
-**bundleName**: bundle name of the application.
-`app_signature`: fingerprint information of the application. For details, see **Configuration in install_list_capability.json** in [Application Privilege Configuration Guide](../../device-dev/subsystems/subsys-app-privilege-config-guide.md).
-**app_signature**: fingerprint information of the application. For details, see **Configuration in install_list_capability.json** in [Application Privilege Configuration Guide](../../device-dev/subsystems/subsys-app-privilege-config-guide.md).
-**permissions**: **name** specifies the name of the **user_grant** permission to pre-authorize. **userCancellable** specifies whether the user can revoke the pre-authorization. The value **true** means the user can revoke the pre-authorization; the vaue **false** means the opposite.
-**permissions**: **name** specifies the name of the **user_grant** permission to pre-authorize. **userCancellable** specifies whether the user can revoke the pre-authorization. The value **true** means the user can revoke the pre-authorization; the value **false** means the opposite.
> **NOTE**<br>This file is available only for preinstalled applications.
> **NOTE**<br>This file is available only for preinstalled applications.
// Step 2 Use an assertion to compare the obtained result with the expected result.
// Step 2 Use an assertion to compare the obtained result with the expected result.
EXPECT_EQ(4, actual);
EXPECT_EQ(4, actual);
}
}
...
@@ -127,20 +127,22 @@ Example:
...
@@ -127,20 +127,22 @@ Example:
The procedure is as follows:
The procedure is as follows:
1. Add comment information to the test case file header.
1. Add comment information to the test case file header.
Enter the header comment in the standard format. For details, see [Code Specifications](https://gitee.com/openharmony/docs/blob/master/en/contribute/code-contribution.md).
Enter the header comment in the standard format. For details, see [Code Specifications](https://gitee.com/openharmony/docs/blob/master/en/contribute/code-contribution.md).
2. Add the test framework header file and namespace.
2. Add the test framework header file and namespace.
```
```
#include <gtest/gtest.h>
#include <gtest/gtest.h>
using namespace testing::ext;
using namespace testing::ext;
```
```
3. Add the header file of the test class.
```
3. Add the header file of the test class.
```
#include "calculator.h"
#include "calculator.h"
```
```
4. Define the test suite (test class).
4. Define the test suite (test class).
```
```
class CalculatorSubTest : public testing::Test {
class CalculatorSubTest : public testing::Test {
public:
public:
static void SetUpTestCase(void);
static void SetUpTestCase(void);
...
@@ -148,73 +150,84 @@ Example:
...
@@ -148,73 +150,84 @@ Example:
void SetUp();
void SetUp();
void TearDown();
void TearDown();
};
};
void CalculatorSubTest::SetUpTestCase(void)
void CalculatorSubTest::SetUpTestCase(void)
{
{
// Set a setup function, which will be called before all test cases.
// Set a setup function, which will be called before all test cases.
}
}
void CalculatorSubTest::TearDownTestCase(void)
void CalculatorSubTest::TearDownTestCase(void)
{
{
// Set a teardown function, which will be called after all test cases.
// Set a teardown function, which will be called after all test cases.
}
}
void CalculatorSubTest::SetUp(void)
void CalculatorSubTest::SetUp(void)
{
{
// Set a setup function, which will be called before each test case.
// Set a setup function, which will be called before each test case.
}
}
void CalculatorSubTest::TearDown(void)
void CalculatorSubTest::TearDown(void)
{
{
// Set a teardown function, which will be called after each test case.
// Set a teardown function, which will be called after each test case.
}
}
```
```
> **NOTE**<br>When defining a test suite, ensure that the test suite name is the same as the target to build and uses the upper camel case style.
> **NOTE**<br>When defining a test suite, ensure that the test suite name is the same as the target to build and uses the upper camel case style.
5. Add implementation of the test cases, including test case comments and logic.
// Step 1 Call the function to obtain the test result.
int actual = Sub(4, 0);
// Step 2 Use an assertion to compare the obtained result with the expected result.
EXPECT_EQ(4, actual);
}
```
The following test case templates are provided for your reference.
| Template| Description|
5. Add implementation of the test cases, including test case comments and logic.
| ------------| ------------|
| HWTEST(A,B,C)| Use this template if the test case execution does not depend on setup or teardown.|
| HWTEST_F(A,B,C)| Use this template if the test case execution (excluding parameters) depends on setup and teardown.|
| HWTEST_P(A,B,C)| Use this template if the test case execution (including parameters) depends on setup and teardown.|
In the template names:
- *A* indicates the test suite name.
- *B* indicates the test case name, which is in the *Function*\_*No.* format. The *No.* is a three-digit number starting from **001**.
- *C* indicates the test case level. There are five test case levels: guard-control level 0 and non-guard-control level 1 to level 4. Of levels 1 to 4, a smaller value indicates a more important function verified by the test case.
**NOTE**<br>
- The expected result of each test case must have an assertion.
- The test case level must be specified.
- It is recommended that the test be implemented step by step according to the template.
- The comment must contain the test case name, description, type, and requirement number, which are in the @tc.*xxx*: *value* format. The test case description must be in the @tc.xxx format. The test case type @tc.type can be any of the following:
| HWTEST(A,B,C) | Use this template if the test case execution does not depend on setup or teardown. |
| HWTEST_F(A,B,C) | Use this template if the test case execution (excluding parameters) depends on setup and teardown. |
| HWTEST_P(A,B,C) | Use this template if the test case execution (including parameters) depends on setup and teardown. |
In the template names:
- *A* indicates the test suite name.
- *B* indicates the test case name, which is in the *Function*\_*No.* format. The *No.* is a three-digit number starting from **001**.
- *C* indicates the test case level. There are five test case levels: guard-control level 0 and non-guard-control level 1 to level 4. Of levels 1 to 4, a smaller value indicates a more important function verified by the test case.
> **NOTE**
>
> - The expected result of each test case must have an assertion.
>- The test case level must be specified.
> - It is recommended that the test be implemented step by step according to the template.
>- The comment must contain the test case name, description, type, and requirement number, which are in the @tc.*xxx*: *value* format. The test case description must be in the @tc.xxx format. The test case type @tc.type can be any of the following:
| Test Case Type | Code |
| ---------------- | ---- |
| Function test | FUNC |
| Performance test | PERF |
| Reliability test | RELI |
| Security test | SECU |
| Fuzz test | FUZZ |
#### JavaScript Test Case Example
#### JavaScript Test Case Example
...
@@ -262,7 +275,7 @@ Example:
...
@@ -262,7 +275,7 @@ Example:
it("appInfoTest001", 0, function () {
it("appInfoTest001", 0, function () {
// Step 1 Call the function to obtain the test result.
// Step 1 Call the function to obtain the test result.
var info = app.getInfo()
var info = app.getInfo()
// Step 2 Use an assertion to compare the obtained result with the expected result.
// Step 2 Use an assertion to compare the obtained result with the expected result.
expect(info != null).assertEqual(true)
expect(info != null).assertEqual(true)
})
})
...
@@ -271,12 +284,12 @@ Example:
...
@@ -271,12 +284,12 @@ Example:
The procedure is as follows:
The procedure is as follows:
1. Add comment information to the test case file header.
1. Add comment information to the test case file header.
Enter the header comment in the standard format. For details, see [Code Specifications](https://gitee.com/openharmony/docs/blob/master/en/contribute/code-contribution.md).
Enter the header comment in the standard format. For details, see [Code Specifications](https://gitee.com/openharmony/docs/blob/master/en/contribute/code-contribution.md).
2. Import the APIs and JSUnit test library to test.
2. Import the APIs and JSUnit test library to test.
```
```
import app from '@system.app'
import app from '@system.app'
import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index'
import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index'
```
```
3. Define the test suite (test class).
3. Define the test suite (test class).
...
@@ -313,7 +326,7 @@ Example:
...
@@ -313,7 +326,7 @@ Example:
it("appInfoTest001", 0, function () {
it("appInfoTest001", 0, function () {
// Step 1 Call the function to obtain the test result.
// Step 1 Call the function to obtain the test result.
var info = app.getInfo()
var info = app.getInfo()
// Step 2 Use an assertion to compare the obtained result with the expected result.
// Step 2 Use an assertion to compare the obtained result with the expected result.
expect(info != null).assertEqual(true)
expect(info != null).assertEqual(true)
})
})
...
@@ -362,12 +375,13 @@ The following provides templates for different languages for your reference.
...
@@ -362,12 +375,13 @@ The following provides templates for different languages for your reference.
1. Add comment information for the file header.
1. Add comment information for the file header.
Enter the header comment in the standard format. For details, see [Code Specifications](https://gitee.com/openharmony/docs/blob/master/en/contribute/code-contribution.md).
Enter the header comment in the standard format. For details, see [Code Specifications](https://gitee.com/openharmony/docs/blob/master/en/contribute/code-contribution.md).
@@ -391,7 +405,9 @@ The following provides templates for different languages for your reference.
...
@@ -391,7 +405,9 @@ The following provides templates for different languages for your reference.
ohos_unittest("CalculatorSubTest") {
ohos_unittest("CalculatorSubTest") {
}
}
```
```
6. Write the build script (add the source file, configuration, and dependencies) for the test cases.
6. Write the build script (add the source file, configuration, and dependencies) for the test cases.
```
```
ohos_unittest("CalculatorSubTest") {
ohos_unittest("CalculatorSubTest") {
module_out_path = module_output_path
module_out_path = module_output_path
...
@@ -402,30 +418,35 @@ The following provides templates for different languages for your reference.
...
@@ -402,30 +418,35 @@ The following provides templates for different languages for your reference.
]
]
sources += [ "calculator_sub_test.cpp" ]
sources += [ "calculator_sub_test.cpp" ]
configs = [ ":module_private_config" ]
configs = [ ":module_private_config" ]
deps = [ "//third_party/googletest:gtest_main" ]
deps = [ "//third_party/googletest:gtest_main" ]
}
}
```
```
> **NOTE**<br>Set the test type based on actual requirements. The following test types are available:
>
> - **ohos_unittest**: unit test
> - **ohos_moduletest**: module test
> - **ohos_systemtest**: system test
> - **ohos_performancetest**: performance test
> - **ohos_securitytest**: security test
> - **ohos_reliabilitytest**: reliability test
> - **ohos_distributedtest**: distributed test
> **NOTE**
>
> - **ohos_unittest**: unit test
> - **ohos_moduletest**: module test
> - **ohos_systemtest**: system test
> - **ohos_performancetest**: performance test
> - **ohos_securitytest**: security test
> - **ohos_reliabilitytest**: reliability test
> - **ohos_distributedtest**: distributed test
7. Group the test case files by test type.
7. Group the test case files by test type.
```
```
group("unittest") {
group("unittest") {
testonly = true
testonly = true
deps = [":CalculatorSubTest"]
deps = [":CalculatorSubTest"]
}
}
```
```
> **NOTE**<br>Grouping test cases by test type allows you to execute a specific type of test cases when required.
> **NOTE**
>
> Grouping test cses by test type allows you to execute a specific type of test cases when required.
-**Test case build file example (JavaScript)**
-**Test case build file example (JavaScript)**
```
```
...
@@ -451,7 +472,7 @@ The following provides templates for different languages for your reference.
...
@@ -451,7 +472,7 @@ The following provides templates for different languages for your reference.
1. Add comment information for the file header.
1. Add comment information for the file header.
Enter the header comment in the standard format. For details, see [Code Specifications](https://gitee.com/openharmony/docs/blob/master/en/contribute/code-contribution.md).
Enter the header comment in the standard format. For details, see [Code Specifications](https://gitee.com/openharmony/docs/blob/master/en/contribute/code-contribution.md).
2. Import the build template.
2. Import the build template.
...
@@ -485,7 +506,7 @@ The following provides templates for different languages for your reference.
...
@@ -485,7 +506,7 @@ The following provides templates for different languages for your reference.
**config.json** is the configuration file required for HAP build. You need to set **target** based on the tested SDK version. Default values can be retained for other items. The following is an example:
**config.json** is the configuration file required for HAP build. You need to set **target** based on the tested SDK version. Default values can be retained for other items. The following is an example:
```
```
{
{
...
@@ -677,8 +698,9 @@ When the build is complete, the test cases are automatically saved in **out/hisp
...
@@ -677,8 +698,9 @@ When the build is complete, the test cases are automatically saved in **out/hisp
2. Copy **developertest** and **xdevice** from the Linux environment to the **Test** directory on Windows, and copy the test cases to the **testcase** directory.
2. Copy **developertest** and **xdevice** from the Linux environment to the **Test** directory on Windows, and copy the test cases to the **testcase** directory.
>**NOTE**<br>Port the test framework and test cases from the Linux environment to the Windows environment for subsequent execution.
> **NOTE**<br>
>
> Port the test framework and test cases from the Linux environment to the Windows environment for subsequent execution.
3. Modify the **user_config.xml** file.
3. Modify the **user_config.xml** file.
```
```
<build>
<build>
...
@@ -745,7 +767,7 @@ To enable test cases to be executed on a remote Linux server or a Linux VM, map
...
@@ -745,7 +767,7 @@ To enable test cases to be executed on a remote Linux server or a Linux VM, map
The test framework locates the test cases based on the command, and automatically builds and executes the test cases.
The test framework locates the test cases based on the command, and automatically builds and executes the test cases.
```
```
run -t UT -ts CalculatorSubTest -tc integer_sub_00l
run -t UT -ts CalculatorSubTest -tc interger_sub_00l