提交 dadc99bd 编写于 作者: X xinking129

add getrunningprocessInfo

Signed-off-by: Nxinking129 <xinxin13@huawei.com>
上级 705206ff
...@@ -10,7 +10,9 @@ ...@@ -10,7 +10,9 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
import("//build/ohos_var.gni") import("//build/ohos_var.gni")
group("ability_runtime") { group("ability_runtime") {
testonly = true testonly = true
if (is_standard_system) { if (is_standard_system) {
......
...@@ -69,6 +69,10 @@ export default class EntryAbility extends Ability { ...@@ -69,6 +69,10 @@ export default class EntryAbility extends Ability {
globalThis.abilityContext = this.context globalThis.abilityContext = this.context
globalThis.want = want globalThis.want = want
globalThis.applicationContext = this.context.getApplicationContext(); globalThis.applicationContext = this.context.getApplicationContext();
if (globalThis.want.action == 'RegisterOnOffOn') {
globalThis.applicationContext.on('applicationStateChange', ApplicationStateChangeCallbackFir)
globalThis.applicationContext.off('applicationStateChange', ApplicationStateChangeCallbackFir)
}
globalThis.applicationContext.on('applicationStateChange', ApplicationStateChangeCallbackFir) globalThis.applicationContext.on('applicationStateChange', ApplicationStateChangeCallbackFir)
if (globalThis.want.action == 'doubleRegister' || globalThis.want.action == 'doubleNeedBackGroundOff' if (globalThis.want.action == 'doubleRegister' || globalThis.want.action == 'doubleNeedBackGroundOff'
|| globalThis.want.action == 'DoubleRegisterOff') { || globalThis.want.action == 'DoubleRegisterOff') {
......
{
"app": {
"bundleName": "com.example.applicationstatechangethreereply",
"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
}
}
}
# 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("ApplicationStateChangeThreeReply") {
hap_profile = "entry/src/main/module.json"
js_build_mode = "debug"
deps = [
":applicationstatechangethreereply_js_assets",
":applicationstatechangethreereply_resources",
]
ets2abc = true
certificate_profile = "signature/openharmony_sx.p7b"
hap_name = "ApplicationStateChangeThreeReply"
subsystem_name = "ability"
part_name = "ability_runtime"
}
ohos_app_scope("applicationstatechangethreereply_app_profile") {
app_profile = "AppScope/app.json"
sources = [ "AppScope/resources" ]
}
ohos_js_assets("applicationstatechangethreereply_js_assets") {
source_dir = "entry/src/main/ets"
}
ohos_resources("applicationstatechangethreereply_resources") {
sources = [ "entry/src/main/resources" ]
deps = [ ":applicationstatechangethreereply_app_profile" ]
hap_profile = "entry/src/main/module.json"
}
import hilog from '@ohos.hilog';
import Ability from '@ohos.app.ability.UIAbility'
import Window from '@ohos.window'
import commonEvent from '@ohos.commonEvent'
let TAG = 'getRunningProcess'
let commonStateArr
let commonEventData = {
parameters:{
commonStateArr: commonStateArr
}
}
let ApplicationStateChangeCallbackFir = {
onApplicationForeground() {
console.log(TAG,'ApplicationStateChangeCallbackFir onApplicationForeground')
},
onApplicationBackground() {
console.log(TAG,'ApplicationStateChangeCallbackFir onApplicationBackground')
setTimeout(() => {
console.info('Enter onApplicationForeground publish!')
commonEventData.parameters.commonStateArr = 1
commonEvent.publish('processState',commonEventData, (err) => {
console.info("====>processState publish err: " + JSON.stringify(err))
})
},1000)
}
}
let ForegroundTAG = -1
export default class EntryAbility extends Ability {
onCreate(want, launchParam) {
ForegroundTAG = -1
commonEventData.parameters.commonStateArr = -1
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) ?? '');
globalThis.abilityContext1 = this.context
globalThis.want1 = want
globalThis.applicationContext1 = this.context.getApplicationContext();
globalThis.applicationContext1.on('applicationStateChange', ApplicationStateChangeCallbackFir)
}
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() {
// Ability has brought to foreground
ForegroundTAG++
if(ForegroundTAG == 1) {
setTimeout(() => {
commonEvent.publish('processState',commonEventData, (err) => {
console.info("====>processState publish err: " + JSON.stringify(err))
})
},3000)
}
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground');
}
onBackground() {
// Ability has back to background
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground');
}
}
import hilog from '@ohos.hilog';
import Ability from '@ohos.app.ability.UIAbility'
import Window from '@ohos.window'
export default class EntryAbility1 extends Ability {
onCreate(want, launchParam) {
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) ?? '');
globalThis.abilityContext2 = this.context
globalThis.want2 = want
globalThis.applicationContext2 = this.context.getApplicationContext();
}
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() {
// Ability has brought to foreground
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground');
setTimeout(() => {
globalThis.abilityContext2.terminateSelf((err) => {
console.log('terminateSelf result:' + JSON.stringify(err));
})
},3000)
}
onBackground() {
// Ability has back to background
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground');
}
}
@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
@Entry
@Component
struct Index1 {
@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
{
"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"
]
}
]
},
{
"name": "EntryAbility1",
"srcEntrance": "./ets/entryability1/EntryAbility1.ts",
"description": "$string:EntryAbility1_desc",
"icon": "$media:icon",
"label": "$string:EntryAbility1_label",
"startWindowIcon": "$media:icon",
"startWindowBackground": "$color:start_window_background",
"visible": true
}
]
}
}
\ No newline at end of file
{
"color": [
{
"name": "start_window_background",
"value": "#FFFFFF"
}
]
}
\ No newline at end of file
{
"string": [
{
"name": "module_desc",
"value": "module description"
},
{
"name": "EntryAbility_desc",
"value": "description"
},
{
"name": "EntryAbility_label",
"value": "label"
},
{
"name": "EntryAbility1_desc",
"value": "description"
},
{
"name": "EntryAbility1_label",
"value": "label"
}
]
}
\ No newline at end of file
{
"string": [
{
"name": "module_desc",
"value": "module description"
},
{
"name": "EntryAbility_desc",
"value": "description"
},
{
"name": "EntryAbility_label",
"value": "label"
},
{
"name": "EntryAbility1_desc",
"value": "description"
},
{
"name": "EntryAbility1_label",
"value": "label"
}
]
}
\ No newline at end of file
{
"string": [
{
"name": "module_desc",
"value": "模块描述"
},
{
"name": "EntryAbility_desc",
"value": "description"
},
{
"name": "EntryAbility_label",
"value": "label"
},
{
"name": "EntryAbility1_desc",
"value": "description"
},
{
"name": "EntryAbility1_label",
"value": "label"
}
]
}
\ No newline at end of file
...@@ -18,9 +18,11 @@ group("getrunningprocessinformation") { ...@@ -18,9 +18,11 @@ group("getrunningprocessinformation") {
if (is_standard_system) { if (is_standard_system) {
deps = [ deps = [
"ApplicationStateChangeOneReply:ApplicationStateChangeOneReply", "ApplicationStateChangeOneReply:ApplicationStateChangeOneReply",
"ApplicationStateChangeThreeReply:ApplicationStateChangeThreeReply",
"ApplicationStateChangeTwoReply:ApplicationStateChangeTwoReply", "ApplicationStateChangeTwoReply:ApplicationStateChangeTwoReply",
"GetRunningProcessInformationOneReply:GetRunningProcessInformationOneReply", "GetRunningProcessInformationOneReply:GetRunningProcessInformationOneReply",
"GetRunningProcessInformationTest:GetRunningProcessInformationTest", "GetRunningProcessInformationTest:GetRunningProcessInformationTest",
"GetRunningProcessInformationTwoReply:GetRunningProcessInformationTwoReply",
] ]
} }
} }
...@@ -2,103 +2,91 @@ import hilog from '@ohos.hilog'; ...@@ -2,103 +2,91 @@ import hilog from '@ohos.hilog';
import Ability from '@ohos.app.ability.UIAbility' import Ability from '@ohos.app.ability.UIAbility'
import Window from '@ohos.window' import Window from '@ohos.window'
import commonEvent from '@ohos.commonEvent' import commonEvent from '@ohos.commonEvent'
import AbilityConstant from '@ohos.app.ability.AbilityConstant'
let commonStateArr: number[] = [2,2,2,3,3,3] let sequence = 0;
let TAG = 'GetRunningProcessInformation'
let commonStateArr: number[] = [-1,-1,-1,-1]
let commonEventData={ let commonEventData={
parameters:{ parameters:{
"commonStateArr": commonStateArr commonStateArr: commonStateArr
} }
} }
let TAG = 'Runningprocessinformation' globalThis.StartFloatingAbility = () => {
let want = {
export default class EntryAbility extends Ability { "deviceId": "",
onCreate(want, launchParam) { "bundleName": "com.example.getrunningprocessinformationtworeply", //
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); "abilityName": "EntryAbility"
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate'); };
hilog.info(0x0000, 'testTag', '%{public}s', 'want param:' + JSON.stringify(want) ?? ''); let options = {
hilog.info(0x0000, 'testTag', '%{public}s', 'launchParam:' + JSON.stringify(launchParam) ?? ''); windowMode: AbilityConstant.WindowMode.WINDOW_MODE_FLOATING,
};
globalThis.abilityContext.startAbility(want, options, (error) => {
console.log(TAG,"start floating ability error.code = " + error.code)
})
}
globalThis.want = want globalThis.StartNormalAbility = () => {
globalThis.abilityContext = this.context let want = {
globalThis.applicationContext = this.context.getApplicationContext(); "deviceId": "",
"bundleName": "com.example.getrunningprocessinformationtworeply", //
"abilityName": "EntryAbility"
};
globalThis.abilityContext.startAbility(want, (error) => {
console.log(TAG, "start normal ability error.code = " + error.code)
})
}
if (globalThis.want.action == 'Callback') { globalThis.GetRunningProcessInfoCallback = () => {
globalThis.applicationContext.getRunningProcessInformation((err,data) => { globalThis.applicationContext.getRunningProcessInformation((err,data) => {
if (err) { if (err) {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err)); console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
} }
else { else {
console.log(TAG,'Oncreate Callback State: ' + JSON.stringify(data[0].state)); console.log(TAG,'Oncreate Callback State: ' + JSON.stringify(data[0].state));
commonStateArr[0] = data[0].state commonStateArr[sequence++] = data[0].state
} }
}) })
} }
else if (globalThis.want.action == 'Promise') {
globalThis.GetRunningProcessInfoPromise = () => {
globalThis.applicationContext.getRunningProcessInformation().then((data) => { globalThis.applicationContext.getRunningProcessInformation().then((data) => {
console.log(TAG,'Oncreate Promise State: ' + JSON.stringify(data[0].state)); console.log(TAG,'Oncreate Promise State: ' + JSON.stringify(data[0].state));
commonStateArr[0] = data[0].state commonStateArr[sequence++] = data[0].state
}).catch((err) => { }).catch((err) => {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err)); console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
}); });
} }
}
onDestroy() {
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onDestroy');
if (globalThis.want.action == 'Callback') {
globalThis.applicationContext.getRunningProcessInformation((err,data) => {
if (err) {
console.log(TAG,'Ondestroy Callback State: ' + JSON.stringify(err));
}
else {
console.log(TAG,'Ondestroy Callback State: ' + JSON.stringify(data[0].state));
commonStateArr[5] = data[0].state
globalThis.PublishStateArray = () => {
commonEvent.publish('processState',commonEventData, (err) => { commonEvent.publish('processState',commonEventData, (err) => {
console.info("====>processState publish err: " + JSON.stringify(err)) console.info("====>processState publish err: " + JSON.stringify(err))
}) })
}
export default class EntryAbility extends Ability {
onCreate(want, launchParam) {
sequence = 0
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) ?? '');
globalThis.want = want
globalThis.abilityContext = this.context
globalThis.applicationContext = this.context.getApplicationContext();
} }
})
} onDestroy() {
else if (globalThis.want.action == 'Promise') { hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
globalThis.applicationContext.getRunningProcessInformation().then((data) => { hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onDestroy');
console.log(TAG,'Ondestroy Promise State: ' + JSON.stringify(data[0].state));
commonStateArr[5] = data[0].state
commonEvent.publish('processState',commonEventData, (err) => {
console.info("====>processState publish err: " + JSON.stringify(err))
})
}).catch((err) => {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
});
}
} }
onWindowStageCreate(windowStage: Window.WindowStage) { onWindowStageCreate(windowStage: Window.WindowStage) {
// Main window is created, set main page for this ability // Main window is created, set main page for this ability
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate'); hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate');
if (globalThis.want.action == 'Callback') {
globalThis.applicationContext.getRunningProcessInformation((err,data) => {
if (err) {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
}
else {
console.log(TAG,'Onwindowstagecreate Callback State: ' + JSON.stringify(data[0].state));
commonStateArr[1] = data[0].state
}
})
}
else if (globalThis.want.action == 'Promise') {
globalThis.applicationContext.getRunningProcessInformation().then((data) => {
console.log(TAG,'Onwindowstagecreate Promise State: ' + JSON.stringify(data[0].state));
commonStateArr[1] = data[0].state
}).catch((err) => {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
});
}
windowStage.loadContent('pages/Index', (err, data) => { windowStage.loadContent('pages/Index', (err, data) => {
if (err.code) { if (err.code) {
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.ERROR); hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.ERROR);
...@@ -110,88 +98,21 @@ export default class EntryAbility extends Ability { ...@@ -110,88 +98,21 @@ export default class EntryAbility extends Ability {
}); });
} }
async onWindowStageDestroy() { onWindowStageDestroy() {
// Main window is destroyed, release UI related resources // Main window is destroyed, release UI related resources
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageDestroy'); hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageDestroy');
if (globalThis.want.action == 'Callback') {
globalThis.applicationContext.getRunningProcessInformation((err,data) => {
if (err) {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
}
else {
console.log(TAG,'Onwindowstagedestroy Callback State: ' + JSON.stringify(data[0].state));
commonStateArr[4] = data[0].state
}
})
}
else if (globalThis.want.action == 'Promise') {
await globalThis.applicationContext.getRunningProcessInformation().then((data) => {
console.log(TAG,'Onwindowstagedestroy Promise State: ' + JSON.stringify(data[0].state));
commonStateArr[2] = data[4].state
}).catch((err) => {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
});
}
} }
async onForeground() { onForeground() {
// Ability has brought to foreground // Ability has brought to foreground
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground'); hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground');
if (globalThis.want.action == 'Callback') {
globalThis.applicationContext.getRunningProcessInformation((err,data) => {
if (err) {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
}
else {
console.log(TAG,'Onforeground Callback State: ' + JSON.stringify(data[0].state));
commonStateArr[2] = data[0].state
globalThis.abilityContext.terminateSelf((err) => {
console.log(TAG,'terminateSelf result:' + JSON.stringify(err));
});
}
})
}
else if (globalThis.want.action == 'Promise') {
await globalThis.applicationContext.getRunningProcessInformation().then((data) => {
console.log(TAG,'Onforeground Promise State: ' + JSON.stringify(data[0].state));
commonStateArr[2] = data[0].state
}).catch((err) => {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
});
}
await setTimeout(() => {
globalThis.abilityContext.terminateSelf((err) => {
console.log(TAG,'terminateSelf result:' + JSON.stringify(err));
});
},4000)
} }
async onBackground() { onBackground() {
// Ability has back to background // Ability has back to background
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground'); hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground');
if (globalThis.want.action == 'Callback') {
globalThis.applicationContext.getRunningProcessInformation((err,data) => {
if (err) {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
}
else {
console.log(TAG,'Onbackground Callback State: ' + JSON.stringify(data[0].state));
commonStateArr[3] = data[0].state
}
})
}
// else if (globalThis.want.action == 'Promise') {
await globalThis.applicationContext.getRunningProcessInformation().then((data) => {
console.log(TAG,'Onbackground Promise State: ' + JSON.stringify(data[0].state));
commonStateArr[3] = data[0].state
}).catch((err) => {
console.log(TAG,`getRunningProcessInformation err: ` + JSON.stringify(err));
});
// }
} }
} }
...@@ -6,9 +6,104 @@ struct Index { ...@@ -6,9 +6,104 @@ struct Index {
build() { build() {
Row() { Row() {
Column() { Column() {
Text(this.message) Button() {
.fontSize(50) Text('get BackInfo')
.fontSize(25)
.fontWeight(FontWeight.Bold) .fontWeight(FontWeight.Bold)
.fontColor('#FFFFFF')
}
.id('Backtest')
.type(ButtonType.Capsule)
.margin({ top: 30 })
.backgroundColor('#87CEEB')
.width('90%')
.height('6%')
.onClick(() => {
if (globalThis.want.action == 'Callback') {
setTimeout(() => {
globalThis.StartNormalAbility()
},500)
setTimeout(() => {
globalThis.GetRunningProcessInfoCallback()
},3000)
setTimeout(() => {
globalThis.PublishStateArray()
},5000)
}
else if (globalThis.want.action == 'Promise') {
setTimeout(() => {
globalThis.StartNormalAbility()
},500)
setTimeout(() => {
globalThis.GetRunningProcessInfoPromise()
},3000)
setTimeout(() => {
globalThis.PublishStateArray()
},5000)
}
})
Button() {
Text('get unFocusedInfo')
.fontSize(25)
.fontWeight(FontWeight.Bold)
.fontColor('#FFFFFF')
}
.id('unFocusedtest')
.type(ButtonType.Capsule)
.margin({ top: 30 })
.backgroundColor('#87CEEB')
.width('90%')
.height('6%')
.onClick(() => {
if (globalThis.want.action == 'Callback') {
setTimeout(() => {
globalThis.StartFloatingAbility()
},500)
setTimeout(() => {
globalThis.GetRunningProcessInfoCallback()
},2500)
}
else if (globalThis.want.action == 'Promise') {
setTimeout(() => {
globalThis.StartFloatingAbility()
},500)
setTimeout(() => {
globalThis.GetRunningProcessInfoPromise()
},2500)
}
})
Button() {
Text('get focusedInfo')
.fontSize(25)
.fontWeight(FontWeight.Bold)
.fontColor('#FFFFFF')
}
.id('Focustest')
.type(ButtonType.Capsule)
.margin({ top: 30 })
.backgroundColor('#87CEEB')
.width('90%')
.height('6%')
.onClick(() => {
if (globalThis.want.action == 'Callback') {
setTimeout(() => {
globalThis.GetRunningProcessInfoCallback()
},500)
}
else if (globalThis.want.action == 'Promise') {
setTimeout(() => {
globalThis.GetRunningProcessInfoPromise()
},500)
}
})
} }
.width('100%') .width('100%')
} }
......
...@@ -6,13 +6,15 @@ ...@@ -6,13 +6,15 @@
"bundle-name": "com.example.getrunningprocessinformationtest", "bundle-name": "com.example.getrunningprocessinformationtest",
"module-name": "entry_test", "module-name": "entry_test",
"shell-timeout": "600000", "shell-timeout": "600000",
"testcase-timeout": "15000" "testcase-timeout": "30000"
}, },
"kits": [ "kits": [
{ {
"test-file-name": [ "test-file-name": [
"GetRunningProcessInformationTest.hap", "GetRunningProcessInformationTest.hap",
"GetRunningProcessInformationOneReply.hap", "GetRunningProcessInformationOneReply.hap",
"GetRunningProcessInformationTwoReply.hap",
"ApplicationStateChangeThreeReply.hap",
"ApplicationStateChangeOneReply.hap", "ApplicationStateChangeOneReply.hap",
"ApplicationStateChangeTwoReply.hap" "ApplicationStateChangeTwoReply.hap"
], ],
......
{
"app": {
"bundleName": "com.example.getrunningprocessinformationtworeply",
"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
}
}
}
# 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("GetRunningProcessInformationTwoReply") {
hap_profile = "entry/src/main/module.json"
js_build_mode = "debug"
deps = [
":getrunningprocessinformationtworeply_js_assets",
":getrunningprocessinformationtworeply_resources",
]
ets2abc = true
certificate_profile = "signature/openharmony_sx.p7b"
hap_name = "GetRunningProcessInformationTwoReply"
subsystem_name = "ability"
part_name = "ability_runtime"
}
ohos_app_scope("getrunningprocessinformationtworeply_app_profile") {
app_profile = "AppScope/app.json"
sources = [ "AppScope/resources" ]
}
ohos_js_assets("getrunningprocessinformationtworeply_js_assets") {
source_dir = "entry/src/main/ets"
}
ohos_resources("getrunningprocessinformationtworeply_resources") {
sources = [ "entry/src/main/resources" ]
deps = [ ":getrunningprocessinformationtworeply_app_profile" ]
hap_profile = "entry/src/main/module.json"
}
import hilog from '@ohos.hilog';
import Ability from '@ohos.app.ability.UIAbility'
import Window from '@ohos.window'
export default class EntryAbility extends Ability {
onCreate(want, launchParam) {
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() {
// Ability has brought to foreground
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground');
}
onBackground() {
// Ability has back to background
hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground');
}
}
@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
{
"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
{
"color": [
{
"name": "start_window_background",
"value": "#FFFFFF"
}
]
}
\ No newline at end of file
{
"string": [
{
"name": "module_desc",
"value": "module description"
},
{
"name": "EntryAbility_desc",
"value": "description"
},
{
"name": "EntryAbility_label",
"value": "label"
}
]
}
\ No newline at end of file
{
"string": [
{
"name": "module_desc",
"value": "module description"
},
{
"name": "EntryAbility_desc",
"value": "description"
},
{
"name": "EntryAbility_label",
"value": "label"
}
]
}
\ No newline at end of file
{
"string": [
{
"name": "module_desc",
"value": "模块描述"
},
{
"name": "EntryAbility_desc",
"value": "description"
},
{
"name": "EntryAbility_label",
"value": "label"
}
]
}
\ No newline at end of file
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册