提交 79e4bab3 编写于 作者: Z zhouyan

将系统api从acts中移除

Signed-off-by: Nzhouyan <zhouyan128@huawei.com>
上级 ca7e84e2
...@@ -17,7 +17,6 @@ group("security") { ...@@ -17,7 +17,6 @@ group("security") {
testonly = true testonly = true
if (is_standard_system) { if (is_standard_system) {
deps = [ deps = [
"access_token/AccessTokenTest_NoPermission_js:ActsAccessTokenJSApiTestNoPermission",
"access_token/AccessTokenTest_Normal_js:ActsAccessTokenJSApiTestNormal", "access_token/AccessTokenTest_Normal_js:ActsAccessTokenJSApiTestNormal",
"huks_standard", "huks_standard",
"security_huks_basic", "security_huks_basic",
......
# Copyright (C) 2021 Huawei Device Co., Ltd.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import("//test/xts/tools/build/suite.gni")
ohos_js_hap_suite("ActsAccessTokenJSApiTestNoPermission") {
hap_profile = "./src/main/config.json"
deps = [
":accesstoken_js_assets",
":accesstoken_resources",
]
certificate_profile = "./signature/openharmony_sx.p7b"
hap_name = "ActsAccessTokenJSApiTestNoPermission"
}
ohos_js_assets("accesstoken_js_assets") {
source_dir = "./src/main/js/default"
}
ohos_resources("accesstoken_resources") {
sources = [ "./src/main/resources" ]
hap_profile = "./src/main/config.json"
}
{
"description": "Configuration for osaccount js api Tests",
"driver": {
"type": "JSUnitTest",
"test-timeout": "60000",
"package": "ohos.acts.security.access_token.nopermission",
"shell-timeout": "60000"
},
"kits": [
{
"test-file-name": [
"ActsAccessTokenJSApiTestNoPermission.hap"
],
"type": "AppInstallKit",
"cleanup-apps": true
}
]
}
\ No newline at end of file
{
"app": {
"bundleName": "ohos.acts.security.access_token.nopermission",
"vendor": "acts",
"version": {
"code": 1000000,
"name": "1.0.0"
},
"apiVersion": {
"compatible": 4,
"target": 5,
"releaseType": "Release"
}
},
"deviceConfig": {},
"module": {
"package": "ohos.acts.security.access_token.nopermission",
"name": ".MyApplication",
"deviceType": [
"phone"
],
"distro": {
"deliveryWithInstall": true,
"moduleName": "entry",
"moduleType": "entry"
},
"definePermissions": [
{
"name": "ohos.permission.ALPHA",
"grantMode": "user_grant",
"availableLevel": "system_basic",
"provisionEnable": true,
"distributedSceneEnable": true,
"label": "ALPHA label",
"description": "ALPHA description"
},
{
"name": "ohos.permission.BETA",
"grantMode": "system_grant",
"availableLevel": "system_basic",
"provisionEnable": true,
"distributedSceneEnable": true,
"label": "BETA label",
"description": "BETA description"
}
],
"abilities": [
{
"visible":true,
"skills": [
{
"entities": [
"entity.system.home"
],
"actions": [
"action.system.home"
]
}
],
"name": "ohos.acts.security.access_token.nopermission.MainAbility",
"icon": "$media:icon",
"description": "$string:mainability_description",
"label": "$string:app_name",
"type": "page",
"launchType": "standard"
}
],
"js": [
{
"pages": [
"pages/index/index"
],
"name": "default",
"window": {
"designWidth": 720,
"autoDesignWidth": false
}
}
],
"reqPermissions": [
{
"name": "ohos.permission.GET_BUNDLE_INFO_PRIVILEGED"
},
{
"name": "ohos.permission.GET_BUNDLE_INFO"
}
]
}
}
/*
* Copyright (C) 2021 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export default {
onCreate() {
console.info('ohos.acts.distributeddatamgr.distributedfile onCreate');
},
onDestroy() {
console.info('ohos.acts.distributeddatamgr.distributedfile onCreate');
}
};
{
"strings": {
"hello": "Hello",
"world": "Test"
}
}
\ No newline at end of file
{
"strings": {
"hello": "您好",
"world": "测试"
}
}
\ No newline at end of file
.container {
flex-direction: column;
justify-content: center;
align-items: center;
}
.title {
font-size: 100px;
}
<div class="container">
<text class="title">
{{ $t('strings.hello') }} {{ title }}
</text>
</div>
/*
* Copyright (C) 2021 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import app from '@system.app'
import {Core, ExpectExtend} from 'deccjsunit/index'
export default {
data: {
title: ''
},
onInit() {
this.title = this.$t('strings.world');
},
onShow() {
console.info('onShow finish')
const core = Core.getInstance()
const expectExtend = new ExpectExtend({
'id':'extend'
})
core.addService('expect',expectExtend)
core.init()
const configService = core.getDefaultService('config')
this.timeout = 10000
configService.setConfig(this)
require('../../test/List.test')
core.execute()
},
onReady() {
},
}
/*
* Copyright (C) 2021 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permission and
* limitations under the License.
*/
// @ts-nocheck
import {describe, beforeEach, afterEach, it, expect} from 'deccjsunit/index'
import abilityAccessCtrl from '@ohos.abilityAccessCtrl'
import bundle from '@ohos.bundle'
var PermissionFlag = {
PERMISSION_USER_SET: 1,
PERMISSION_USER_FIXED: 2,
PERMISSION_SYSTEM_FIXED: 3
};
const RESULT_FAIL = -1
const TIMEOUT = 1000;
const DEFAULT_PERMISSION_FALG = 0
var permissionNameUser = "ohos.permission.ALPHA";
var tokenID = undefined
describe('AccessTokenTest',function(){
console.log('##########start AccessTokenTests');
beforeAll(async function (done){
var appInfo = await bundle.getApplicationInfo('ohos.acts.security.access_token.nopermission',0 ,100);
tokenID = appInfo.accessTokenId;
console.log("AccessTokenTest accessTokenId:" + appInfo.accessTokenId + ", name:"+ appInfo.name
+ ", bundleName:" + appInfo.bundleName)
console.info("sleep begin");
sleep(TIMEOUT);
console.info("sleep end");
done();
})
afterEach(function(){
})
function sleep(delay){
var start = (new Date()).getTime();
var next = (new Date()).getTime();
while (next - start < delay){
next = (new Date()).getTime();
}
}
/**
* @tc.number Test_grantUserGrantedPermission_007
* @tc.name Test atManager.grantUserGrantedPermission.
* @tc.desc Grant permission that has ohos.permission.GRANT_SENSITIVE_PERMISSIONS.
*/
it('Test_grantUserGrantedPermission_007', 0, async function(done){
console.info("sleep begin");
sleep(1000);
console.info("sleep end");
console.log("Test_grantUserGrantedPermission_007 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.grantUserGrantedPermission(tokenID, permissionNameUser,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_grantUserGrantedPermission_007 tokenID"+ tokenID + "-" + result)
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_revokeUserGrantedPermission_007
* @tc.name Test atManager.grantUserGrantedPermission.
* @tc.desc Revoke permission that has ohos.permission.GRANT_SENSITIVE_PERMISSIONS.
*/
it('Test_revokeUserGrantedPermission_007', 0, async function(done){
console.log("Test_revokeUserGrantedPermission_007 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.revokeUserGrantedPermission(tokenID, permissionNameUser,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_revokeUserGrantedPermission_007 tokenID"+ tokenID + "-" + result)
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_getPermissionFlags_005
* @tc.name Test atManager.getPermissionFlags.
* @tc.desc Get permission flag that has ohos.permission.GRANT_SENSITIVE_PERMISSIONS.
*/
it('Test_getPermissionFlags_005', 0, async function(done){
console.log("Test_getPermissionFlags_005 start");
console.log("Test_getPermissionFlags_005 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.getPermissionFlags(tokenID, permissionNameUser);
console.log("Test_getPermissionFlags_005 tokenID"+ tokenID + "-" + result)
expect(result).assertEqual(DEFAULT_PERMISSION_FALG);
done();
})
})
/*
* Copyright (C) 2021 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permission and
* limitations under the License.
*/
require('./AccessToken.test.js')
\ No newline at end of file
{
"string": [
{
"name": "app_name",
"value": "AccessTokenTest"
},
{
"name": "mainability_description",
"value": "JS_Phone_Empty Feature Ability"
}
]
}
\ No newline at end of file
{ {
"strings": { "strings": {
"hello": "Hello", "hello": "Hello",
"world": "Test" "world": "World"
} }
} }
\ No newline at end of file
...@@ -139,286 +139,4 @@ describe('AccessTokenTest', function () { ...@@ -139,286 +139,4 @@ describe('AccessTokenTest', function () {
done(); done();
}) })
/**
* @tc.number Test_grantUserGrantedPermission_001
* @tc.name Test atManager.grantUserGrantedPermission.
* @tc.desc Test grant user_grant permission(Promise).
*/
it('Test_grantUserGrantedPermission_001', 0, async function(done){
console.log("Test_grantUserGrantedPermission_001 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.grantUserGrantedPermission(tokenID, permissionNameUser,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_grantUserGrantedPermission_001 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_SUCCESS);
var result1 = await atManager.verifyAccessToken(tokenID, permissionNameUser);
console.log("Test_grantUserGrantedPermission_001 tokenID" + tokenID + "-result1" + result1)
expect(result1).assertEqual(GrantStatus.PERMISSION_GRANTED);
done();
})
/**
* @tc.number Test_grantUserGrantedPermission_002
* @tc.name Test atManager.grantUserGrantedPermission.
* @tc.desc Test grant user_grant permission(Promise).
*/
it('Test_grantUserGrantedPermission_002', 0, async function(done){
console.log("Test_grantUserGrantedPermission_002 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.grantUserGrantedPermission(tokenID, permissionNameSystem,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_grantUserGrantedPermission_002 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_grantUserGrantedPermission_003
* @tc.name Test atManager.grantUserGrantedPermission.
* @tc.desc Test grant user_grant permission(Promise).
*/
it('Test_grantUserGrantedPermission_003', 0, async function(done){
console.log("Test_grantUserGrantedPermission_003 start");
var atManager = abilityAccessCtrl.createAtManager();
atManager.grantUserGrantedPermission(tokenID, permissionNameUser, PermissionFlag.PERMISSION_USER_SET,
function (err, result) {
console.log("Test_grantUserGrantedPermission_003 tokenID" + tokenID + "-" + result)
expect(result).assertEqual(RESULT_SUCCESS);
atManager.verifyAccessToken(tokenID, permissionNameUser).then(function (result1) {
console.log("Test_grantUserGrantedPermission_003 tokenID" + tokenID + "-result1" + result1)
expect(result1).assertEqual(GrantStatus.PERMISSION_GRANTED);
});
done();
});
})
/**
* @tc.number Test_grantUserGrantedPermission_004
* @tc.name Test atManager.grantUserGrantedPermission.
* @tc.desc Test invalid TokenID(0)(Promise).
*/
it('Test_grantUserGrantedPermission_004', 0, async function(done){
console.log("Test_grantUserGrantedPermission_004 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.grantUserGrantedPermission(0, permissionNameUser,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_grantUserGrantedPermission_004 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_grantUserGrantedPermission_005
* @tc.name Test atManager.grantUserGrantedPermission.
* @tc.desc Test invalid permission(empty)(Promise).
*/
it('Test_grantUserGrantedPermission_005', 0, async function(done){
console.log("Test_grantUserGrantedPermission_005 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.grantUserGrantedPermission(tokenID, "", PermissionFlag.PERMISSION_USER_SET);
console.log("Test_grantUserGrantedPermission_005 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_grantUserGrantedPermission_006
* @tc.name Test atManager.grantUserGrantedPermission.
* @tc.desc Test invalid permission(length exceeds 256)(Promise).
*/
it('Test_grantUserGrantedPermission_006', 0, async function(done){
console.log("Test_grantUserGrantedPermission_006 start");
var atManager = abilityAccessCtrl.createAtManager();
var permissionName = "ohos.permission.testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest"
+ "testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest"
+ "testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest";
var result = await atManager.grantUserGrantedPermission(tokenID, permissionName,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_grantUserGrantedPermission_006 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_revokeUserGrantedPermission_001
* @tc.name Test atManager.revokeUserGrantedPermission.
* @tc.desc Test revoke user_grant permission(Promise).
*/
it('Test_revokeUserGrantedPermission_001', 0, async function(done){
console.log("Test_revokeUserGrantedPermission_001 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.revokeUserGrantedPermission(tokenID, permissionNameUser,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_revokeUserGrantedPermission_001 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_SUCCESS);
var result1 = await atManager.verifyAccessToken(tokenID, permissionNameUser);
console.log("Test_revokeUserGrantedPermission_001 tokenID" + tokenID + "-result1" + result1)
expect(result1).assertEqual(GrantStatus.PERMISSION_DENIED);
done();
})
/**
* @tc.number Test_revokeUserGrantedPermission_002
* @tc.name Test atManager.revokeUserGrantedPermission.
* @tc.desc Test revoke system_grant permission(Promise).
*/
it('Test_revokeUserGrantedPermission_002', 0, async function(done){
console.log("Test_revokeUserGrantedPermission_002 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.revokeUserGrantedPermission(tokenID, permissionNameSystem,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_revokeUserGrantedPermission_002 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_revokeUserGrantedPermission_003
* @tc.name Test atManager.revokeUserGrantedPermission.
* @tc.desc Test revoke user_grant permission(AsyncCallback).
*/
it('Test_revokeUserGrantedPermission_003', 0, async function(done){
console.log("Test_revokeUserGrantedPermission_003 start");
var atManager = abilityAccessCtrl.createAtManager();
atManager.revokeUserGrantedPermission(tokenID, permissionNameUser, PermissionFlag.PERMISSION_USER_SET,
function (err, result) {
console.log("Test_revokeUserGrantedPermission_003 tokenID" + tokenID + "-" + result)
expect(result).assertEqual(RESULT_SUCCESS);
atManager.verifyAccessToken(tokenID, permissionNameUser).then(function (result1) {
console.log("Test_revokeUserGrantedPermission_003 tokenID" + tokenID + "-result1" + result1)
expect(result1).assertEqual(GrantStatus.PERMISSION_DENIED);
});
done();
});
})
/**
* @tc.number Test_revokeUserGrantedPermission_004
* @tc.name Test atManager.revokeUserGrantedPermission.
* @tc.desc Test invalid TokenID(0)(Promise).
*/
it('Test_revokeUserGrantedPermission_004', 0, async function(done){
console.log("Test_revokeUserGrantedPermission_004 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.revokeUserGrantedPermission(0, permissionNameUser,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_revokeUserGrantedPermission_004 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_revokeUserGrantedPermission_005
* @tc.name Test atManager.revokeUserGrantedPermission.
* @tc.desc Test invalid permission(empty)(Promise).
*/
it('Test_revokeUserGrantedPermission_005', 0, async function(done){
console.log("Test_revokeUserGrantedPermission_005 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.revokeUserGrantedPermission(tokenID, "", PermissionFlag.PERMISSION_USER_SET);
console.log("Test_revokeUserGrantedPermission_005 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_revokeUserGrantedPermission_006
* @tc.name Test atManager.revokeUserGrantedPermission.
* @tc.desc Test invalid permission(length exceeds 256)(Promise).
*/
it('Test_revokeUserGrantedPermission_006', 0, async function(done){
console.log("Test_revokeUserGrantedPermission_006 start");
var atManager = abilityAccessCtrl.createAtManager();
var permissionName = "ohos.permission.testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest"
+ "testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest"
+ "testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest";
var result = await atManager.revokeUserGrantedPermission(tokenID, permissionName,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_revokeUserGrantedPermission_006 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_FAIL);
done();
})
/**
* @tc.number Test_getPermissionFlag_001
* @tc.name Test atManager.getPermissionFlags.
* @tc.desc Test get permission flag(Promise).
*/
it('Test_getPermissionFlag_001', 0, async function(done){
console.log("Test_getPermissionFlag_001 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.grantUserGrantedPermission(tokenID, permissionNameUser,
PermissionFlag.PERMISSION_USER_SET);
console.log("Test_getPermissionFlag_001 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(RESULT_SUCCESS);
var result1 = await atManager.getPermissionFlags(tokenID, permissionNameUser);
console.log("Test_getPermissionFlag_001 tokenID" + tokenID + "-result1" + result1)
expect(result1).assertEqual(PermissionFlag.PERMISSION_USER_SET);
done();
})
/**
* @tc.number Test_getPermissionFlag_002
* @tc.name Test atManager.getPermissionFlags.
* @tc.desc Test invalid TokenID(0)(Promise).
*/
it('Test_getPermissionFlag_002', 0, async function(done){
console.log("Test_getPermissionFlag_002 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.getPermissionFlags(0, permissionNameUser);
console.log("Test_getPermissionFlag_002 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(DEFAULT_PERMISSION_FALG);
done();
})
/**
* @tc.number Test_getPermissionFlag_003
* @tc.name Test atManager.getPermissionFlags.
* @tc.desc Test invalid permission(empty)(Promise).
*/
it('Test_getPermissionFlag_003', 0, async function(done){
console.log("Test_getPermissionFlag_003 start");
var atManager = abilityAccessCtrl.createAtManager();
var result = await atManager.getPermissionFlags(tokenID, "");
console.log("Test_getPermissionFlag_003 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(DEFAULT_PERMISSION_FALG);
done();
})
/**
* @tc.number Test_getPermissionFlag_004
* @tc.name Test atManager.getPermissionFlags.
* @tc.desc Test invalid permission(length exceeds 256)(Promise).
*/
it('Test_getPermissionFlag_004', 0, async function(done){
console.log("Test_getPermissionFlag_004 start");
var atManager = abilityAccessCtrl.createAtManager();
var permissionName = "ohos.permission.testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest"
+ "testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest"
+ "testtesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttesttest";
var result = await atManager.getPermissionFlags(tokenID, permissionName);
console.log("Test_getPermissionFlag_004 tokenID" + tokenID + "-" + result);
expect(result).assertEqual(DEFAULT_PERMISSION_FALG);
done();
})
}) })
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
"string": [ "string": [
{ {
"name": "app_name", "name": "app_name",
"value": "Storagestatfsjstest" "value": "AccessTokenJsTestNormal"
}, },
{ {
"name": "mainability_description", "name": "mainability_description",
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册