Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Xts Acts
提交
1c436c2b
X
Xts Acts
项目概览
OpenHarmony
/
Xts Acts
1 年多 前同步成功
通知
9
Star
22
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
X
Xts Acts
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
1c436c2b
编写于
3月 31, 2023
作者:
O
openharmony_ci
提交者:
Gitee
3月 31, 2023
浏览文件
操作
浏览文件
下载
差异文件
!7956 Js层Error回调增强ST测试
Merge pull request !7956 from xinking129/master
上级
6a61440b
1d21e971
变更
32
隐藏空白更改
内联
并排
Showing
32 changed file
with
1225 addition
and
0 deletion
+1225
-0
ability/ability_runtime/BUILD.gn
ability/ability_runtime/BUILD.gn
+1
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/AppScope/app.json
...registerjserror/ActsRegisterJsErrorRely/AppScope/app.json
+19
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/AppScope/resources/base/element/string.json
...erJsErrorRely/AppScope/resources/base/element/string.json
+8
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/AppScope/resources/base/media/app_icon.png
...terJsErrorRely/AppScope/resources/base/media/app_icon.png
+0
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/BUILD.gn
..._runtime/registerjserror/ActsRegisterJsErrorRely/BUILD.gn
+43
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/ets/entryability/EntryAbility.ts
...ErrorRely/entry/src/main/ets/entryability/EntryAbility.ts
+167
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/ets/pages/Index.ets
...ctsRegisterJsErrorRely/entry/src/main/ets/pages/Index.ets
+31
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/module.json
...serror/ActsRegisterJsErrorRely/entry/src/main/module.json
+37
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/base/element/color.json
...rrorRely/entry/src/main/resources/base/element/color.json
+8
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/base/element/string.json
...rorRely/entry/src/main/resources/base/element/string.json
+16
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/base/media/icon.png
...rJsErrorRely/entry/src/main/resources/base/media/icon.png
+0
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/base/profile/main_pages.json
...ely/entry/src/main/resources/base/profile/main_pages.json
+5
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/en_US/element/string.json
...orRely/entry/src/main/resources/en_US/element/string.json
+16
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/zh_CN/element/string.json
...orRely/entry/src/main/resources/zh_CN/element/string.json
+16
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/signature/openharmony_sx.p7b
...rror/ActsRegisterJsErrorRely/signature/openharmony_sx.p7b
+0
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/AppScope/app.json
...registerjserror/ActsRegisterJsErrorTest/AppScope/app.json
+19
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/AppScope/resources/base/element/string.json
...erJsErrorTest/AppScope/resources/base/element/string.json
+8
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/AppScope/resources/base/media/app_icon.png
...terJsErrorTest/AppScope/resources/base/media/app_icon.png
+0
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/BUILD.gn
..._runtime/registerjserror/ActsRegisterJsErrorTest/BUILD.gn
+43
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/Test.json
...runtime/registerjserror/ActsRegisterJsErrorTest/Test.json
+31
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts
...st/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts
+85
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/test/Ability.test.ets
...isterJsErrorTest/entry/src/main/ets/test/Ability.test.ets
+437
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/test/List.test.ets
...RegisterJsErrorTest/entry/src/main/ets/test/List.test.ets
+19
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/testability/TestAbility.ets
...sErrorTest/entry/src/main/ets/testability/TestAbility.ets
+72
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/testability/pages/Index.ets
...sErrorTest/entry/src/main/ets/testability/pages/Index.ets
+49
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/module.json
...serror/ActsRegisterJsErrorTest/entry/src/main/module.json
+42
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/resources/base/element/color.json
...rrorTest/entry/src/main/resources/base/element/color.json
+8
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/resources/base/element/string.json
...rorTest/entry/src/main/resources/base/element/string.json
+16
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/resources/base/media/icon.png
...rJsErrorTest/entry/src/main/resources/base/media/icon.png
+0
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/resources/base/profile/test_pages.json
...est/entry/src/main/resources/base/profile/test_pages.json
+5
-0
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/signature/openharmony_sx.p7b
...rror/ActsRegisterJsErrorTest/signature/openharmony_sx.p7b
+0
-0
ability/ability_runtime/registerjserror/BUILD.gn
ability/ability_runtime/registerjserror/BUILD.gn
+24
-0
未找到文件。
ability/ability_runtime/BUILD.gn
浏览文件 @
1c436c2b
...
...
@@ -53,6 +53,7 @@ group("ability_runtime") {
"freeinstalltest:freeinstalltest",
"newwant:newwant",
"non_concurrent:non_concurrent",
"registerjserror:registerjserror",
"stage:stage",
"want:want",
"workercontextcover:workercontextcover",
...
...
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/AppScope/app.json
0 → 100644
浏览文件 @
1c436c2b
{
"app"
:
{
"bundleName"
:
"com.example.actsregisterjserrorrely"
,
"vendor"
:
"example"
,
"versionCode"
:
1000000
,
"versionName"
:
"1.0.0"
,
"icon"
:
"$media:app_icon"
,
"label"
:
"$string:app_name"
,
"distributedNotificationEnabled"
:
true
,
"keepAlive"
:
true
,
"singleUser"
:
true
,
"minAPIVersion"
:
10
,
"targetAPIVersion"
:
10
,
"car"
:
{
"apiCompatibleVersion"
:
10
,
"singleUser"
:
false
}
}
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/AppScope/resources/base/element/string.json
0 → 100644
浏览文件 @
1c436c2b
{
"string"
:
[
{
"name"
:
"app_name"
,
"value"
:
"ActsRegisterJsErrorRely"
}
]
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/AppScope/resources/base/media/app_icon.png
0 → 100644
浏览文件 @
1c436c2b
6.6 KB
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/BUILD.gn
0 → 100644
浏览文件 @
1c436c2b
# Copyright (c) 2023 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_hap_assist_suite("ActsRegisterJsErrorRely") {
hap_profile = "entry/src/main/module.json"
js_build_mode = "debug"
deps = [
":actsregisterjserrorrely_js_assets",
":actsregisterjserrorrely_resources",
]
ets2abc = true
certificate_profile = "signature/openharmony_sx.p7b"
hap_name = "ActsRegisterJsErrorRely"
subsystem_name = "ability"
part_name = "ability_runtime"
}
ohos_app_scope("actsregisterjserrorrely_app_profile") {
app_profile = "AppScope/app.json"
sources = [ "AppScope/resources" ]
}
ohos_js_assets("actsregisterjserrorrely_js_assets") {
source_dir = "entry/src/main/ets"
}
ohos_resources("actsregisterjserrorrely_resources") {
sources = [ "entry/src/main/resources" ]
deps = [ ":actsregisterjserrorrely_app_profile" ]
hap_profile = "entry/src/main/module.json"
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/ets/entryability/EntryAbility.ts
0 → 100644
浏览文件 @
1c436c2b
/*
* Copyright (c) 2023 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
hilog
from
'
@ohos.hilog
'
;
import
Ability
from
'
@ohos.app.ability.UIAbility
'
import
Window
from
'
@ohos.window
'
import
commonEvent
from
'
@ohos.commonEvent
'
import
ErrorManager
from
"
@ohos.app.ability.errorManager
"
let
message
;
let
commonEventData
=
{
parameters
:{
message
:
message
,
}
}
export
default
class
EntryAbility
extends
Ability
{
onCreate
(
want
,
launchParam
)
{
globalThis
.
want
=
want
;
globalThis
.
context
=
this
.
context
;
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
Ability onCreate
'
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
want param:
'
+
JSON
.
stringify
(
want
)
??
''
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
launchParam:
'
+
JSON
.
stringify
(
launchParam
)
??
''
);
}
onDestroy
()
{
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
Ability onDestroy
'
);
}
onWindowStageCreate
(
windowStage
:
Window
.
WindowStage
)
{
// Main window is created, set main page for this ability
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
Ability onWindowStageCreate
'
);
windowStage
.
loadContent
(
'
pages/Index
'
,
(
err
,
data
)
=>
{
if
(
err
.
code
)
{
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
ERROR
);
hilog
.
error
(
0x0000
,
'
testTag
'
,
'
Failed to load the content. Cause: %{public}s
'
,
JSON
.
stringify
(
err
)
??
''
);
return
;
}
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
Succeeded in loading the content. Data: %{public}s
'
,
JSON
.
stringify
(
data
)
??
''
);
});
}
onWindowStageDestroy
()
{
// Main window is destroyed, release UI related resources
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
Ability onWindowStageDestroy
'
);
}
onForeground
()
{
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
Ability onForeground
'
);
let
observer
=
undefined
;
if
(
globalThis
.
want
.
action
==
"
Acts_RegisterJsErrorCallback_0100
"
)
{
observer
=
{
onUnhandledException
(
strMsg
){
commonEventData
.
parameters
.
message
=
strMsg
;
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0100 onUnhandledException Message:
"
+
strMsg
);
commonEvent
.
publish
(
"
ACTS_RegisterEvent_First
"
,
commonEventData
,
(
err
)
=>
{
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0100 publish err:
"
+
JSON
.
stringify
(
err
));
setTimeout
(()
=>
{
globalThis
.
context
.
terminateSelf
().
then
(()
=>
{
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0100 rely terminateSelf end
"
);
}).
catch
((
err
)
=>
{
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0100 rely terminateSelf err:
"
+
JSON
.
stringify
(
err
));
});
},
100
);
})
}
}
ErrorManager
.
on
(
"
error
"
,
observer
);
setTimeout
(()
=>
{
globalThis
.
contest
.
terminateSelf
();
},
300
);
}
else
if
(
globalThis
.
want
.
action
==
"
Acts_RegisterJsErrorCallback_0200
"
)
{
observer
=
{
onUnhandledException
(
strMsg
:
String
){
commonEventData
.
parameters
.
message
=
strMsg
;
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0200 onUnhandledException Message:
"
+
strMsg
);
commonEvent
.
publish
(
"
ACTS_RegisterEvent_First
"
,
commonEventData
,
(
err
)
=>
{
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0200 onUnhandledException publish err:
"
+
JSON
.
stringify
(
err
));
})
},
onException
(
errObject
:
Error
){
commonEventData
.
parameters
.
message
=
errObject
;
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0200 onException Message:
"
+
JSON
.
stringify
(
errObject
));
commonEvent
.
publish
(
"
ACTS_RegisterEvent_Second
"
,
commonEventData
,
(
err
)
=>
{
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0200 onException publish err:
"
+
JSON
.
stringify
(
err
));
setTimeout
(()
=>
{
globalThis
.
context
.
terminateSelf
().
then
(()
=>
{
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0200 rely terminateSelf end
"
);
}).
catch
((
err
)
=>
{
console
.
info
(
"
====>Acts_RegisterJsErrorCallback_0200 rely terminateSelf err:
"
+
JSON
.
stringify
(
err
));
})
},
100
)
})
}
}
ErrorManager
.
on
(
"
error
"
,
observer
);
setTimeout
(()
=>
{
globalThis
.
contest
.
terminateSelf
();
},
300
);
}
else
if
(
globalThis
.
want
.
action
==
"
Acts_UnregisterJsErrorCallback_0800
"
)
{
observer
=
{
onUnhandledException
(
strMsg
:
String
){
commonEventData
.
parameters
.
message
=
strMsg
;
console
.
info
(
"
====>Acts_UnregisterJsErrorCallback_0800 onUnhandledException Message:
"
+
strMsg
);
commonEvent
.
publish
(
"
ACTS_RegisterEvent_First
"
,
commonEventData
,
(
err
)
=>
{
console
.
info
(
"
====>Acts_UnregisterJsErrorCallback_0800 onUnhandledException publish err:
"
+
JSON
.
stringify
(
err
));
})
},
onException
(
errObject
:
Error
){
commonEventData
.
parameters
.
message
=
errObject
;
console
.
info
(
"
====>Acts_UnregisterJsErrorCallback_0800 onException Message:
"
+
JSON
.
stringify
(
errObject
));
commonEvent
.
publish
(
"
ACTS_RegisterEvent_Second
"
,
commonEventData
,
(
err
)
=>
{
console
.
info
(
"
====>Acts_UnregisterJsErrorCallback_0800 onException publish err:
"
+
JSON
.
stringify
(
err
));
setTimeout
(()
=>
{
globalThis
.
context
.
terminateSelf
().
then
(()
=>
{
console
.
info
(
"
====>Acts_UnregisterJsErrorCallback_0800 rely terminateSelf end
"
);
}).
catch
((
err
)
=>
{
console
.
info
(
"
====>Acts_UnregisterJsErrorCallback_0800 rely terminateSelf err:
"
+
JSON
.
stringify
(
err
));
})
},
100
)
})
}
}
ErrorManager
.
on
(
"
error
"
,
observer
);
let
observerId
=
ErrorManager
.
on
(
"
error
"
,
observer
);
ErrorManager
.
off
(
"
error
"
,
observerId
).
then
(()
=>
{
console
.
info
(
"
====>Acts_UnregisterJsErrorCallback_0800 rely off end
"
);
}).
catch
((
err
)
=>
{
console
.
info
(
"
====>Acts_UnregisterJsErrorCallback_0800 rely off err:
"
+
JSON
.
stringify
(
err
));
})
setTimeout
(()
=>
{
globalThis
.
contest
.
terminateSelf
();
},
300
);
}
}
onBackground
()
{
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
Ability onBackground
'
);
}
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/ets/pages/Index.ets
0 → 100644
浏览文件 @
1c436c2b
/*
* Copyright (c) 2023 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.
*/
@Entry
@Component
struct Index {
@State message: string = 'Hello World'
build() {
Row() {
Column() {
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
}
.width('100%')
}
.height('100%')
}
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/module.json
0 → 100644
浏览文件 @
1c436c2b
{
"module"
:
{
"name"
:
"entry"
,
"type"
:
"entry"
,
"description"
:
"$string:module_desc"
,
"mainElement"
:
"EntryAbility"
,
"deviceTypes"
:
[
"default"
,
"tablet"
],
"deliveryWithInstall"
:
true
,
"installationFree"
:
false
,
"pages"
:
"$profile:main_pages"
,
"abilities"
:
[
{
"name"
:
"EntryAbility"
,
"srcEntrance"
:
"./ets/entryability/EntryAbility.ts"
,
"description"
:
"$string:EntryAbility_desc"
,
"icon"
:
"$media:icon"
,
"label"
:
"$string:EntryAbility_label"
,
"startWindowIcon"
:
"$media:icon"
,
"startWindowBackground"
:
"$color:start_window_background"
,
"visible"
:
true
,
"skills"
:
[
{
"entities"
:
[
"entity.system.home"
],
"actions"
:
[
"action.system.home"
]
}
]
}
]
}
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/base/element/color.json
0 → 100644
浏览文件 @
1c436c2b
{
"color"
:
[
{
"name"
:
"start_window_background"
,
"value"
:
"#FFFFFF"
}
]
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/base/element/string.json
0 → 100644
浏览文件 @
1c436c2b
{
"string"
:
[
{
"name"
:
"module_desc"
,
"value"
:
"module description"
},
{
"name"
:
"EntryAbility_desc"
,
"value"
:
"description"
},
{
"name"
:
"EntryAbility_label"
,
"value"
:
"label"
}
]
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/base/media/icon.png
0 → 100644
浏览文件 @
1c436c2b
6.6 KB
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/base/profile/main_pages.json
0 → 100644
浏览文件 @
1c436c2b
{
"src"
:
[
"pages/Index"
]
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/en_US/element/string.json
0 → 100644
浏览文件 @
1c436c2b
{
"string"
:
[
{
"name"
:
"module_desc"
,
"value"
:
"module description"
},
{
"name"
:
"EntryAbility_desc"
,
"value"
:
"description"
},
{
"name"
:
"EntryAbility_label"
,
"value"
:
"RegisterJsErrorRely"
}
]
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/entry/src/main/resources/zh_CN/element/string.json
0 → 100644
浏览文件 @
1c436c2b
{
"string"
:
[
{
"name"
:
"module_desc"
,
"value"
:
"模块描述"
},
{
"name"
:
"EntryAbility_desc"
,
"value"
:
"description"
},
{
"name"
:
"EntryAbility_label"
,
"value"
:
"RegisterJsErrorRely"
}
]
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorRely/signature/openharmony_sx.p7b
0 → 100644
浏览文件 @
1c436c2b
文件已添加
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/AppScope/app.json
0 → 100644
浏览文件 @
1c436c2b
{
"app"
:
{
"bundleName"
:
"com.example.actsregisterjserrortest"
,
"vendor"
:
"example"
,
"versionCode"
:
1000000
,
"versionName"
:
"1.0.0"
,
"icon"
:
"$media:app_icon"
,
"label"
:
"$string:app_name"
,
"distributedNotificationEnabled"
:
true
,
"keepAlive"
:
true
,
"singleUser"
:
true
,
"minAPIVersion"
:
10
,
"targetAPIVersion"
:
10
,
"car"
:
{
"apiCompatibleVersion"
:
10
,
"singleUser"
:
false
}
}
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/AppScope/resources/base/element/string.json
0 → 100644
浏览文件 @
1c436c2b
{
"string"
:
[
{
"name"
:
"app_name"
,
"value"
:
"ActsRegisterJsErrorTest"
}
]
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/AppScope/resources/base/media/app_icon.png
0 → 100644
浏览文件 @
1c436c2b
6.6 KB
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/BUILD.gn
0 → 100644
浏览文件 @
1c436c2b
# Copyright (c) 2023 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("ActsRegisterJsErrorTest") {
hap_profile = "entry/src/main/module.json"
js_build_mode = "debug"
deps = [
":actsregisterjserrortest_js_assets",
":actsregisterjserrortest_resources",
]
ets2abc = true
certificate_profile = "signature/openharmony_sx.p7b"
hap_name = "ActsRegisterJsErrorTest"
subsystem_name = "ability"
part_name = "ability_runtime"
}
ohos_app_scope("actsregisterjserrortest_app_profile") {
app_profile = "AppScope/app.json"
sources = [ "AppScope/resources" ]
}
ohos_js_assets("actsregisterjserrortest_js_assets") {
source_dir = "entry/src/main/ets"
}
ohos_resources("actsregisterjserrortest_resources") {
sources = [ "entry/src/main/resources" ]
deps = [ ":actsregisterjserrortest_app_profile" ]
hap_profile = "entry/src/main/module.json"
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/Test.json
0 → 100644
浏览文件 @
1c436c2b
{
"description"
:
"Configuration for aceceshi Tests"
,
"driver"
:
{
"type"
:
"OHJSUnitTest"
,
"test-timeout"
:
"600000"
,
"bundle-name"
:
"com.example.actsregisterjserrortest"
,
"module-name"
:
"entry_test"
,
"shell-timeout"
:
"600000"
},
"kits"
:
[
{
"test-file-name"
:
[
"ActsRegisterJsErrorTest.hap"
,
"ActsRegisterJsErrorRely.hap"
],
"type"
:
"AppInstallKit"
,
"cleanup-apps"
:
true
},
{
"type"
:
"ShellKit"
,
"run-command"
:
[
"power-shell wakeup"
,
"power-shell setmode 602"
,
"hilog -Q pidoff"
,
"hilog -Q domainoff"
,
"hilog -b D"
,
"setenforce 0"
]
}
]
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts
0 → 100644
浏览文件 @
1c436c2b
/*
* Copyright (c) 2023 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
hilog
from
'
@ohos.hilog
'
;
import
TestRunner
from
'
@ohos.application.testRunner
'
import
AbilityDelegatorRegistry
from
'
@ohos.application.abilityDelegatorRegistry
'
var
abilityDelegator
=
undefined
var
abilityDelegatorArguments
=
undefined
function
translateParamsToString
(
parameters
)
{
const
keySet
=
new
Set
([
'
-s class
'
,
'
-s notClass
'
,
'
-s suite
'
,
'
-s it
'
,
'
-s level
'
,
'
-s testType
'
,
'
-s size
'
,
'
-s timeout
'
,
'
-s dryRun
'
])
let
targetParams
=
''
;
for
(
const
key
in
parameters
)
{
if
(
keySet
.
has
(
key
))
{
targetParams
=
`
${
targetParams
}
${
key
}
${
parameters
[
key
]}
`
}
}
return
targetParams
.
trim
()
}
async
function
onAbilityCreateCallback
()
{
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
onAbilityCreateCallback
'
);
}
async
function
addAbilityMonitorCallback
(
err
:
any
)
{
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
addAbilityMonitorCallback : %{public}s
'
,
JSON
.
stringify
(
err
)
??
''
);
}
export
default
class
OpenHarmonyTestRunner
implements
TestRunner
{
constructor
()
{
}
onPrepare
()
{
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
OpenHarmonyTestRunner OnPrepare
'
);
}
async
onRun
()
{
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
OpenHarmonyTestRunner onRun run
'
);
abilityDelegatorArguments
=
AbilityDelegatorRegistry
.
getArguments
()
abilityDelegator
=
AbilityDelegatorRegistry
.
getAbilityDelegator
()
var
testAbilityName
=
abilityDelegatorArguments
.
bundleName
+
'
.TestAbility
'
let
lMonitor
=
{
abilityName
:
testAbilityName
,
onAbilityCreate
:
onAbilityCreateCallback
,
};
abilityDelegator
.
addAbilityMonitor
(
lMonitor
,
addAbilityMonitorCallback
)
var
cmd
=
'
aa start -d 0 -a TestAbility
'
+
'
-b
'
+
abilityDelegatorArguments
.
bundleName
cmd
+=
'
'
+
translateParamsToString
(
abilityDelegatorArguments
.
parameters
)
var
debug
=
abilityDelegatorArguments
.
parameters
[
'
-D
'
]
if
(
debug
==
'
true
'
)
{
cmd
+=
'
-D
'
}
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
cmd : %{public}s
'
,
cmd
);
abilityDelegator
.
executeShellCommand
(
cmd
,
(
err
:
any
,
d
:
any
)
=>
{
hilog
.
isLoggable
(
0x0000
,
'
testTag
'
,
hilog
.
LogLevel
.
INFO
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
executeShellCommand : err : %{public}s
'
,
JSON
.
stringify
(
err
)
??
''
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
executeShellCommand : data : %{public}s
'
,
d
.
stdResult
??
''
);
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
executeShellCommand : data : %{public}s
'
,
d
.
exitCode
??
''
);
})
hilog
.
info
(
0x0000
,
'
testTag
'
,
'
%{public}s
'
,
'
OpenHarmonyTestRunner onRun end
'
);
}
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/test/Ability.test.ets
0 → 100644
浏览文件 @
1c436c2b
/*
* Copyright (c) 2023 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 { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium'
import ErrorManager from "@ohos.app.ability.errorManager"
import commonEvent from '@ohos.commonEvent'
const CASE_TIME_OUT=5000;
var ACTS_Register = {
events: ["ACTS_RegisterEvent_First", "ACTS_RegisterEvent_Second"]
};
export default function abilityTest() {
describe('ActsAbilityTest', function () {
let observer;
beforeAll(function () {
observer = {
onUnhandledException(strMsg){
console.info("====>Acts_RegisterJsErrorCallback onUnhandledException Message: " + strMsg);
},
onException(errObject){
console.info("====>Acts_RegisterJsErrorCallback onException Message: " + errObject);
}
}
})
/*
* @tc.number: Acts_RegisterJsErrorCallback_0100
* @tc.name: JsError callback enhancement
* @tc.desc: Js registers onUnhandledException callback to listen. There is a callback notification when
* JS is abnormal.
*/
it('Acts_RegisterJsErrorCallback_0100',0, async function (done) {
let subscriber;
let flag = false;
console.info("====>Acts_RegisterJsErrorCallback_0100 start");
commonEvent.createSubscriber(ACTS_Register).then(async (data) => {
console.debug("====>Acts_RegisterJsErrorCallback_0100 Create Subscribe");
subscriber = data;
commonEvent.subscribe(subscriber, subscribeCallBack);
globalThis.abilityContext.startAbility(
{
bundleName: "com.example.actsregisterjserrorrely",
abilityName: "EntryAbility",
action: "Acts_RegisterJsErrorCallback_0100"
},(err)=>{
console.debug("====>Acts_RegisterJsErrorCallback_0100 startAbility err: "+JSON.stringify(err));
expect(err.code).assertEqual(0);
})
})
function subscribeCallBack(err, data) {
console.debug("====>Acts_RegisterJsErrorCallback_0100 subscribeCallBack data: " + JSON.stringify(data));
if(data.event == "ACTS_RegisterEvent_First") {
flag = true;
expect(data.parameters.message).assertContain("Error message:Cannot read property terminateSelf");
commonEvent.unsubscribe(subscriber, unSubscribeCallback);
}
}
function unSubscribeCallback() {
console.debug("====>Acts_RegisterJsErrorCallback_0100 unSubscribeCallback");
setTimeout(()=>{
done();
}, 800);
}
setTimeout(()=>{
if(flag==false){
expect().assertFail();
commonEvent.unsubscribe(subscriber, unSubscribeCallback);
}
},CASE_TIME_OUT)
})
/*
* @tc.number: Acts_RegisterJsErrorCallback_0200
* @tc.name: JsError callback enhancement
* @tc.desc: Js registers onUnhandledException and onException callback to listen. There is a callback
* notification when JS is abnormal.
*/
it('Acts_RegisterJsErrorCallback_0200',0, async function (done) {
let subscriber;
let flag = false;
console.info("====>Acts_RegisterJsErrorCallback_0200 start")
commonEvent.createSubscriber(ACTS_Register).then(async (data) => {
console.debug("====>Acts_RegisterJsErrorCallback_0200 Create Subscribe");
subscriber = data;
commonEvent.subscribe(subscriber, subscribeCallBack);
globalThis.abilityContext.startAbility(
{
bundleName: "com.example.actsregisterjserrorrely",
abilityName: "EntryAbility",
action: "Acts_RegisterJsErrorCallback_0200"
},(err)=>{
console.debug("====>Acts_RegisterJsErrorCallback_0200 startAbility err: "+JSON.stringify(err));
expect(err.code).assertEqual(0);
})
})
var msg = {"ACTS_RegisterEvent_First": false, "ACTS_RegisterEvent_Second": false}
function subscribeCallBack(err, data) {
if (data.event === 'ACTS_RegisterEvent_First') {
console.debug("====>Acts_RegisterJsErrorCallback_0200 subscribeCallBack First data: " + JSON.stringify(data));
expect(data.parameters.message).assertContain("Error message:Cannot read property terminateSelf");
msg["ACTS_RegisterEvent_First"] = true;
} else if (data.event === 'ACTS_RegisterEvent_Second') {
console.debug("====>Acts_RegisterJsErrorCallback_0200 subscribeCallBack Second data: " +
JSON.stringify(data));
expect(data.parameters.message.name).assertEqual("TypeError");
expect(data.parameters.message.message).assertEqual("Cannot read property terminateSelf of undefined");
expect(data.parameters.message.stack).assertContain("at anonymous");
msg["ACTS_RegisterEvent_Second"] = true;
}
if (msg["ACTS_RegisterEvent_First"] == true && msg["ACTS_RegisterEvent_Second"] == true) {
flag = true;
commonEvent.unsubscribe(subscriber, unSubscribeCallback);
}
}
function unSubscribeCallback() {
setTimeout(()=>{
console.debug("====>Acts_RegisterJsErrorCallback_0200 unSubscribeCallback");
done();
}, 800);
}
setTimeout(()=>{
if(flag==false){
expect().assertFail();
commonEvent.unsubscribe(subscriber, unSubscribeCallback);
}
},CASE_TIME_OUT)
})
/*
* @tc.number: Acts_RegisterJsErrorCallback_0300
* @tc.name: JsError callback enhancement
* @tc.desc: When registering JS exception listening interface parameter type is undefined, returns an error.
*/
it('Acts_RegisterJsErrorCallback_0300',0, async function (done) {
console.info("====>Acts_RegisterJsErrorCallback_0300 start");
try {
ErrorManager.on(undefined, observer);
expect().assertFail();
done();
} catch (err) {
console.info("====>Acts_RegisterJsErrorCallback_0300 catch " + JSON.stringify(err.code));
expect(err.code).assertEqual(401);
console.info("====>Acts_RegisterJsErrorCallback_0300 end");
done();
}
})
/*
* @tc.number: Acts_RegisterJsErrorCallback_0400
* @tc.name: JsError callback enhancement
* @tc.desc: When registering JS exception listening interface parameter type is null, returns an error.
*/
it('Acts_RegisterJsErrorCallback_0400',0, async function (done) {
console.info("====>Acts_RegisterJsErrorCallback_0400 start");
try {
ErrorManager.on(null, observer);
expect().assertFail();
done();
} catch (err) {
console.info("====>Acts_RegisterJsErrorCallback_0400 catch " + JSON.stringify(err));
expect(err.code).assertEqual(401);
console.info("====>Acts_RegisterJsErrorCallback_0400 end");
done();
}
})
/*
* @tc.number: Acts_RegisterJsErrorCallback_0500
* @tc.name: JsError callback enhancement
* @tc.desc: When registering JS exception listening interface parameter observer is undefined, no abnormal
* error in interface execution.
*/
it('Acts_RegisterJsErrorCallback_0500',0, async function (done) {
console.info("====>Acts_RegisterJsErrorCallback_0500 start");
try {
ErrorManager.on("error", undefined);
expect(true).assertTrue();
console.info("====>Acts_RegisterJsErrorCallback_0500 end");
done();
} catch (err) {
console.info("====>Acts_RegisterJsErrorCallback_0500 catch " + JSON.stringify(err));
expect().assertFail();
done();
}
})
/*
* @tc.number: Acts_RegisterJsErrorCallback_0600
* @tc.name: JsError callback enhancement
* @tc.desc: When registering JS exception listening interface parameter observer is null, no abnormal
* error in interface execution.
*/
it('Acts_RegisterJsErrorCallback_0600',0, async function (done) {
console.info("====>Acts_RegisterJsErrorCallback_0600 start");
try {
ErrorManager.on("error", null);
expect(true).assertTrue();
console.info("====>Acts_RegisterJsErrorCallback_0600 end");
done();
} catch (err) {
console.info("====>Acts_RegisterJsErrorCallback_0600 catch " + JSON.stringify(err));
expect().assertFail();
done();
}
})
/*
* @tc.number: Acts_UnregisterJsErrorCallback_0100
* @tc.name: JsError callback enhancement
* @tc.desc: When unregistering JS exception listening interface parameter type is undefined, returns an error.
*/
it('Acts_UnregisterJsErrorCallback_0100',0, async function (done) {
console.info("====>Acts_UnregisterJsErrorCallback_0100 start");
let observerId = ErrorManager.on("error", observer);
try {
ErrorManager.off(undefined, observerId).then(()=>{
console.info("====>Acts_UnregisterJsErrorCallback_0100 success");
expect().assertFail();
done();
}).catch((err)=>{
console.info("====>Acts_UnregisterJsErrorCallback_0100 err: " + JSON.stringify(err));
expect(err.code).assertEqual(401);
done();
})
} catch (err) {
console.info("====>Acts_UnregisterJsErrorCallback_0100 catch: " + JSON.stringify(err));
expect(err.code).assertEqual(401);
console.info("====>Acts_UnregisterJsErrorCallback_0100 end");
done();
}
})
/*
* @tc.number: Acts_UnregisterJsErrorCallback_0200
* @tc.name: JsError callback enhancement
* @tc.desc: When unregistering JS exception listening interface parameter type is null, returns an error.
*/
it('Acts_UnregisterJsErrorCallback_0200',0, async function (done) {
console.info("====>Acts_UnregisterJsErrorCallback_0200 start");
let observerId = ErrorManager.on("error", observer);
try {
ErrorManager.off(null, observerId).then(()=>{
console.info("====>Acts_UnregisterJsErrorCallback_0200 success");
expect().assertFail();
done();
}).catch((err)=>{
console.info("====>Acts_UnregisterJsErrorCallback_0200 err: " + JSON.stringify(err));
expect(err.code).assertEqual(401);
done();
})
} catch (err) {
console.info("====>Acts_UnregisterJsErrorCallback_0200 catch: " + JSON.stringify(err));
expect(err.code).assertEqual(401);
console.info("====>Acts_UnregisterJsErrorCallback_0200 end");
done();
}
})
/*
* @tc.number: Acts_UnregisterJsErrorCallback_0300
* @tc.name: JsError callback enhancement
* @tc.desc: When unregistering JS exception listening interface parameter observerId is undefined, returns error.
*/
it('Acts_UnregisterJsErrorCallback_0300',0, async function (done) {
console.info("====>Acts_UnregisterJsErrorCallback_0300 start");
ErrorManager.off("error", undefined).then(()=>{
console.info("====>Acts_UnregisterJsErrorCallback_0300 success");
expect().assertFail();
done();
}).catch((err)=>{
console.info("====>Acts_UnregisterJsErrorCallback_0300 err: " + JSON.stringify(err));
expect(err.code).assertEqual(401);
done();
})
})
/*
* @tc.number: Acts_UnregisterJsErrorCallback_0400
* @tc.name: JsError callback enhancement
* @tc.desc: When unregistering JS exception listening interface parameter observerId is null, returns error.
*/
it('Acts_UnregisterJsErrorCallback_0400',0, async function (done) {
console.info("====>Acts_UnregisterJsErrorCallback_0400 start");
ErrorManager.off("error", null).then(()=>{
console.info("====>Acts_UnregisterJsErrorCallback_0400 success");
expect().assertFail();
done();
}).catch((err)=>{
console.info("====>Acts_UnregisterJsErrorCallback_0400 err: " + JSON.stringify(err));
expect(err.code).assertEqual(401);
done();
})
})
/*
* @tc.number: Acts_UnregisterJsErrorCallback_0500
* @tc.name: JsError callback enhancement
* @tc.desc: When unregistering JS exception listening interface parameter observerId is -1, returns error.
*/
it('Acts_UnregisterJsErrorCallback_0500',0, async function (done) {
console.info("====>Acts_UnregisterJsErrorCallback_0500 start");
ErrorManager.off("error", -1).then(()=>{
console.info("====>Acts_UnregisterJsErrorCallback_0500 success");
expect().assertFail();
done();
}).catch((err)=>{
console.info("====>Acts_UnregisterJsErrorCallback_0500 err: " + JSON.stringify(err));
expect(err.code).assertEqual(401);
done();
})
})
/*
* @tc.number: Acts_UnregisterJsErrorCallback_0600
* @tc.name: JsError callback enhancement
* @tc.desc: When unregistering JS exception listening interface parameter observerId is 10000, returns error.
*/
it('Acts_UnregisterJsErrorCallback_0600',0, async function (done) {
console.info("====>Acts_UnregisterJsErrorCallback_0600 start");
ErrorManager.off("error", 10000).then(()=>{
console.info("====>Acts_UnregisterJsErrorCallback_0600 success");
expect().assertFail();
done();
}).catch((err)=>{
console.info("====>Acts_UnregisterJsErrorCallback_0600 err: " + JSON.stringify(err));
expect(err.code).assertEqual(16000003);
done();
})
})
/*
* @tc.number: Acts_UnregisterJsErrorCallback_0700
* @tc.name: JsError callback enhancement
* @tc.desc: When the parameter objectId of the unregistered JS exception listening interface is the correct
* registered value, the interface executes correctly.
*/
it('Acts_UnregisterJsErrorCallback_0700',0, async function (done) {
console.info("====>Acts_UnregisterJsErrorCallback_0700 start");
let observerId = ErrorManager.on("error", observer);
try {
ErrorManager.off("error", observerId).then(()=>{
console.info("====>Acts_UnregisterJsErrorCallback_0700 end");
expect(true).assertTrue();
done();
}).catch((err)=>{
console.info("====>Acts_UnregisterJsErrorCallback_0700 err: " + JSON.stringify(err));
expect().assertFail();
done();
})
} catch (err) {
console.info("====>Acts_UnregisterJsErrorCallback_0700 catch: " + JSON.stringify(err));
expect().assertFail();
done();
}
})
/*
* @tc.number: Acts_UnregisterJsErrorCallback_0800
* @tc.name: JsError callback enhancement
* @tc.desc: When unregistered as the correct registered value, the interface executes correctly and the JS
* layer does not trigger an exception error callback.
*/
it('Acts_UnregisterJsErrorCallback_0800',0, async function (done) {
let subscriber;
let flag = false;
console.info("====>Acts_UnregisterJsErrorCallback_0800 start")
commonEvent.createSubscriber(ACTS_Register).then(async (data) => {
console.debug("====>Acts_UnregisterJsErrorCallback_0800 Create Subscribe");
subscriber = data;
commonEvent.subscribe(subscriber, subscribeCallBack);
globalThis.abilityContext.startAbility(
{
bundleName: "com.example.actsregisterjserrorrely",
abilityName: "EntryAbility",
action: "Acts_UnregisterJsErrorCallback_0800"
},(err)=>{
console.debug("====>Acts_UnregisterJsErrorCallback_0800 startAbility err: "+JSON.stringify(err));
expect(err.code).assertEqual(0);
})
})
var msg = {"ACTS_RegisterEvent_First": false, "ACTS_RegisterEvent_Second": false}
function subscribeCallBack(err, data) {
if (data.event === 'ACTS_RegisterEvent_First') {
console.debug("====>Acts_UnregisterJsErrorCallback_0800 subscribeCallBack First data: " +
JSON.stringify(data));
expect(data.parameters.message).assertContain("Error message:Cannot read property terminateSelf");
msg["ACTS_RegisterEvent_First"] = true;
} else if (data.event === 'ACTS_RegisterEvent_Second') {
console.debug("====>Acts_UnregisterJsErrorCallback_0800 subscribeCallBack Second data: " +
JSON.stringify(data));
expect(data.parameters.message.name).assertEqual("TypeError");
expect(data.parameters.message.message).assertEqual("Cannot read property terminateSelf of undefined");
expect(data.parameters.message.stack).assertContain("at anonymous");
msg["ACTS_RegisterEvent_Second"] = true;
}
if (msg["ACTS_RegisterEvent_First"] == true && msg["ACTS_RegisterEvent_Second"] == true) {
flag = true;
commonEvent.unsubscribe(subscriber, unSubscribeCallback);
}
}
function unSubscribeCallback() {
setTimeout(() => {
console.debug("====>Acts_UnregisterJsErrorCallback_0800 unSubscribeCallback");
done();
}, 800);
}
setTimeout(()=>{
if(flag==false){
expect().assertFail();
commonEvent.unsubscribe(subscriber, unSubscribeCallback);
}
},CASE_TIME_OUT)
})
})
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/test/List.test.ets
0 → 100644
浏览文件 @
1c436c2b
/*
* Copyright (c) 2023 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 abilityTest from './Ability.test'
export default function testsuite() {
abilityTest()
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/testability/TestAbility.ets
0 → 100644
浏览文件 @
1c436c2b
/*
* Copyright (c) 2023 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 hilog from '@ohos.hilog';
import Ability from '@ohos.app.ability.UIAbility'
import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
import { Hypium } from '@ohos/hypium'
import testsuite from '../test/List.test'
import Window from '@ohos.window'
export default class TestAbility extends Ability {
onCreate(want, launchParam) {
globalThis.abilityContext = this.context;
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onCreate');
hilog.info(0x0000, 'testTag', '%{public}s', 'want param:' + JSON.stringify(want) ?? '');
hilog.info(0x0000, 'testTag', '%{public}s', 'launchParam:'+ JSON.stringify(launchParam) ?? '');
var abilityDelegator: any
abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
var abilityDelegatorArguments: any
abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'start run testcase!!!');
Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
}
onDestroy() {
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onDestroy');
}
onWindowStageCreate(windowStage: Window.WindowStage) {
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onWindowStageCreate');
windowStage.loadContent('testability/pages/Index', (err, data) => {
if (err.code) {
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.ERROR);
hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? '');
return;
}
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', 'Succeeded in loading the content. Data: %{public}s',
JSON.stringify(data) ?? '');
});
}
onWindowStageDestroy() {
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onWindowStageDestroy');
}
onForeground() {
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onForeground');
}
onBackground() {
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onBackground');
}
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/ets/testability/pages/Index.ets
0 → 100644
浏览文件 @
1c436c2b
/*
* Copyright (c) 2023 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 hilog from '@ohos.hilog';
@Entry
@Component
struct Index {
aboutToAppear() {
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility index aboutToAppear');
}
@State message: string = 'Hello World'
build() {
Row() {
Column() {
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
Button() {
Text('next page')
.fontSize(20)
.fontWeight(FontWeight.Bold)
}.type(ButtonType.Capsule)
.margin({
top: 20
})
.backgroundColor('#0D9FFB')
.width('35%')
.height('5%')
.onClick(()=>{
})
}
.width('100%')
}
.height('100%')
}
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/module.json
0 → 100644
浏览文件 @
1c436c2b
{
"module"
:
{
"name"
:
"entry_test"
,
"type"
:
"feature"
,
"description"
:
"$string:module_test_desc"
,
"mainElement"
:
"TestAbility"
,
"deviceTypes"
:
[
"default"
,
"tablet"
],
"deliveryWithInstall"
:
true
,
"installationFree"
:
false
,
"pages"
:
"$profile:test_pages"
,
"abilities"
:
[
{
"name"
:
"TestAbility"
,
"srcEntrance"
:
"./ets/testability/TestAbility.ets"
,
"description"
:
"$string:TestAbility_desc"
,
"icon"
:
"$media:icon"
,
"label"
:
"$string:TestAbility_label"
,
"visible"
:
true
,
"startWindowIcon"
:
"$media:icon"
,
"startWindowBackground"
:
"$color:start_window_background"
,
"skills"
:
[
{
"actions"
:
[
"action.system.home"
],
"entities"
:
[
"entity.system.home"
]
}
]
}
],
"requestPermissions"
:
[
{
"name"
:
"ohos.permission.START_ABILITIES_FROM_BACKGROUND"
}
]
}
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/resources/base/element/color.json
0 → 100644
浏览文件 @
1c436c2b
{
"color"
:
[
{
"name"
:
"start_window_background"
,
"value"
:
"#FFFFFF"
}
]
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/resources/base/element/string.json
0 → 100644
浏览文件 @
1c436c2b
{
"string"
:
[
{
"name"
:
"module_test_desc"
,
"value"
:
"test ability description"
},
{
"name"
:
"TestAbility_desc"
,
"value"
:
"the test ability"
},
{
"name"
:
"TestAbility_label"
,
"value"
:
"test label"
}
]
}
\ No newline at end of file
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/resources/base/media/icon.png
0 → 100644
浏览文件 @
1c436c2b
6.6 KB
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/entry/src/main/resources/base/profile/test_pages.json
0 → 100644
浏览文件 @
1c436c2b
{
"src"
:
[
"testability/pages/Index"
]
}
ability/ability_runtime/registerjserror/ActsRegisterJsErrorTest/signature/openharmony_sx.p7b
0 → 100644
浏览文件 @
1c436c2b
文件已添加
ability/ability_runtime/registerjserror/BUILD.gn
0 → 100644
浏览文件 @
1c436c2b
# Copyright (c) 2023 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")
group("registerjserror") {
testonly = true
if (is_standard_system) {
deps = [
"ActsRegisterJsErrorRely:ActsRegisterJsErrorRely",
"ActsRegisterJsErrorTest:ActsRegisterJsErrorTest",
]
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录