提交 52d4d835 编写于 作者: Z zhangxin_T

modify continuous task xts testcase

Signed-off-by: Nzhangxin_T <zhangxin312@huawei.com>
上级 7e622d72
...@@ -18,6 +18,7 @@ group("resourceschedule_standard") { ...@@ -18,6 +18,7 @@ group("resourceschedule_standard") {
if (is_standard_system) { if (is_standard_system) {
deps = [ deps = [
"backgroundtaskmanager:resourceschedule_backgroundtaskmanager_js_test", "backgroundtaskmanager:resourceschedule_backgroundtaskmanager_js_test",
"continuoustaskrelyhap:ContinuousTaskRelyHap",
"deviceusagestatisticsjsunit:resourceschedule_deviceusagestatisticsjsunit_js_test", "deviceusagestatisticsjsunit:resourceschedule_deviceusagestatisticsjsunit_js_test",
"reminderagent:resourceschedule_reminderagent_js_test", "reminderagent:resourceschedule_reminderagent_js_test",
"workscheduler:resourceschedule_workscheduler_js_test", "workscheduler:resourceschedule_workscheduler_js_test",
......
...@@ -13,6 +13,30 @@ ...@@ -13,6 +13,30 @@
], ],
"type": "AppInstallKit", "type": "AppInstallKit",
"cleanup-apps": true "cleanup-apps": true
},
{
"type": "ShellKit",
"run-command": [
"remount",
"mkdir /data/test"
]
},
{
"type": "PushKit",
"push": [
"ContinuousTaskRelyHap.hap->/data/test/ContinuousTaskRelyHap.hap"
]
},
{
"type": "ShellKit",
"run-command": [
"bm install -p /data/test/ContinuousTaskRelyHap.hap",
"aa start -a com.example.continuoustaskserver.MainAbility -b com.example.continuoustaskserver"
],
"teardown-command": [
"bm uninstall -n com.example.continuoustaskserver",
"rm -rf data/test"
]
} }
] ]
} }
...@@ -13,13 +13,13 @@ ...@@ -13,13 +13,13 @@
* limitations under the License. * limitations under the License.
*/ */
import notification from '@ohos.notification'; import backgroundTaskManager from '@ohos.backgroundTaskManager';
import wantAgent from '@ohos.wantAgent'; import featureAbility from '@ohos.ability.featureAbility';
import particleAbility from '@ohos.ability.particleAbility' import commonEvent from '@ohos.commonEvent';
import backgroundTaskManager from '@ohos.backgroundTaskManager'
import featureAbility from '@ohos.ability.featureAbility'
import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index';
const TAG = "ContinuousTaskJsTest ";
describe("ContinuousTaskJsTest", function () { describe("ContinuousTaskJsTest", function () {
beforeAll(function() { beforeAll(function() {
...@@ -27,7 +27,7 @@ describe("ContinuousTaskJsTest", function () { ...@@ -27,7 +27,7 @@ describe("ContinuousTaskJsTest", function () {
/* /*
* @tc.setup: setup invoked before all testcases * @tc.setup: setup invoked before all testcases
*/ */
console.info('beforeAll called') console.info('beforeAll called');
}) })
afterAll(function() { afterAll(function() {
...@@ -35,7 +35,7 @@ describe("ContinuousTaskJsTest", function () { ...@@ -35,7 +35,7 @@ describe("ContinuousTaskJsTest", function () {
/* /*
* @tc.teardown: teardown invoked after all testcases * @tc.teardown: teardown invoked after all testcases
*/ */
console.info('afterAll called') console.info('afterAll called');
}) })
beforeEach(function() { beforeEach(function() {
...@@ -43,7 +43,7 @@ describe("ContinuousTaskJsTest", function () { ...@@ -43,7 +43,7 @@ describe("ContinuousTaskJsTest", function () {
/* /*
* @tc.setup: setup invoked before each testcases * @tc.setup: setup invoked before each testcases
*/ */
console.info('beforeEach called') console.info('beforeEach called');
}) })
afterEach(function() { afterEach(function() {
...@@ -51,341 +51,151 @@ describe("ContinuousTaskJsTest", function () { ...@@ -51,341 +51,151 @@ describe("ContinuousTaskJsTest", function () {
/* /*
* @tc.teardown: teardown invoked after each testcases * @tc.teardown: teardown invoked after each testcases
*/ */
console.info('afterEach called') console.info('afterEach called');
particleAbility.cancelBackgroundRunning();
setTimeout(() => {}, 500);
backgroundTaskManager.stopBackgroundRunning(featureAbility.getContext());
setTimeout(() => {}, 500);
}) })
/* async function startAbilityWithOption(subscribeInfo, option, event, done) {
* @tc.name:ContinuousTaskJsTest001 commonEvent.createSubscriber(subscribeInfo, (err, subscriber) => {
* @tc.desc:verify new startBackgroundrunning interface promise mode work properly if (subscriber !== null && subscriber !== undefined) {
* @tc.type: FUNC console.info(TAG + "Subscribe begin");
* @tc.require: commonEvent.subscribe(subscriber, (err, data) => {
*/ if (data !== null && data !== undefined) {
it("ContinuousTaskJsTest001", 0, async function (done) { console.info(TAG + "Get comment event: " + JSON.stringify(data));
let wantAgentInfo = { if (data.event === event) {
wants: [
{
bundleName: "com.continuoustask.test",
abilityName: "com.continuoustask.test.MainAbility"
}
],
operationType: 2,
requestCode: 0,
wantAgentFlags: [3]
};
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
backgroundTaskManager.BackgroundMode.DATA_TRANSFER, data).then(() => {
console.log("ContinuousTaskJsTest001 startBackgroundRunning success");
expect(true).assertTrue(); expect(true).assertTrue();
setTimeout(() => { } else {
expect(false).assertTrue();
}
} else {
console.error(TAG + "SubscribeCallBack failed");
expect(false).assertTrue();
}
done(); done();
}, 500); })
}).catch((err) => { } else {
console.error(TAG + "createSubscriber failed");
expect(false).assertTrue(); expect(false).assertTrue();
console.log("ContinuousTaskJsTest001 startBackgroundRunning failure"); done();
}
})
setTimeout(() => { setTimeout(() => {
console.info(TAG + "Start ability with option:" + option + " begin");
featureAbility.startAbility(
{
want: {
bundleName: "com.example.continuoustaskserver",
abilityName: "com.example.continuoustaskserver.ServiceAbility",
parameters: {
option: option
}
}
}
).catch(() => {
console.error(TAG + "Start ability failed");
expect(false).assertTrue();
done(); done();
}, 500);
});
}); });
}, 1000);
}
/*
* @tc.name:ContinuousTaskJsTest001
* @tc.desc:verify old startBackgroundrunning interface callback mode work properly
* @tc.type: FUNC
* @tc.require:
*/
it("ContinuousTaskJsTest001", 0, async function (done) {
console.info(TAG + '-----------------ContinuousTaskJsTest001 begin--------------------');
startAbilityWithOption({ events: ["startTaskUseApi7Callback"] }, "testcase1", "startTaskUseApi7Callback", done);
}) })
/* /*
* @tc.name:ContinuousTaskJsTest002 * @tc.name:ContinuousTaskJsTest002
* @tc.desc:verify new startBackgroundrunning interface callback mode work properly * @tc.desc:verify cancelBackgroundrunning interface callback mode work properly
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest002", 0, async function (done) { it("ContinuousTaskJsTest002", 0, async function (done) {
function conTaskCallback(err, data) { console.info(TAG + '-----------------ContinuousTaskJsTest002 begin--------------------');
if (err) { startAbilityWithOption({ events: ["stopTaskUseApi7Callback"] }, "testcase2", "stopTaskUseApi7Callback", done);
console.info('ContinuousTaskJsTest002 startBackgroundRunning failed');
expect(false).assertTrue();
} else {
console.info('ContinuousTaskJsTest002 startBackgroundRunning succeed');
expect(true).assertTrue();
}
setTimeout(()=>{
done();
}, 500);
}
let wantAgentInfo = {
wants: [
{
bundleName: "com.continuoustask.test",
abilityName: "com.continuoustask.test.MainAbility"
}
],
operationType: 2,
requestCode: 0,
wantAgentFlags: [3]
};
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
backgroundTaskManager.BackgroundMode.DATA_TRANSFER, data, conTaskCallback);
});
}) })
/* /*
* @tc.name:ContinuousTaskJsTest003 * @tc.name:ContinuousTaskJsTest003
* @tc.desc:verify old startBackgroundrunning interface promise mode work properly * @tc.desc:verify new startBackgroundrunning interface callback mode work properly
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest003", 0, async function (done) { it("ContinuousTaskJsTest003", 0, async function (done) {
let wantAgentInfo = { console.info(TAG + '-----------------ContinuousTaskJsTest003 begin--------------------');
wants: [ startAbilityWithOption({ events: ["startTaskUseApi8Callback"] }, "testcase3", "startTaskUseApi8Callback", done);
{
bundleName: "com.continuoustask.test",
abilityName: "com.continuoustask.test.MainAbility"
}
],
operationType: 2,
requestCode: 0,
wantAgentFlags: [3]
};
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
let basicContent = {
title: "title",
text: "text"
};
let notificationContent = {
contentType: notification.ContentType.NOTIFICATION_CONTENT_BASIC_TEXT,
normal: basicContent
};
let request = {
content: notificationContent,
wantAgent: data
}
let id = 1;
particleAbility.startBackgroundRunning(id, request).then((data) => {
console.log("ContinuousTaskJsTest003 startBackgroundRunning success");
expect(true).assertTrue();
setTimeout(() => {
done();
}, 500);
}).catch((err) => {
expect(false).assertTrue();
console.log("ContinuousTaskJsTest003 startBackgroundRunning failure");
setTimeout(() => {
done();
}, 500);
});
});
}) })
/* /*
* @tc.name:ContinuousTaskJsTest004 * @tc.name:ContinuousTaskJsTest004
* @tc.desc:verify old startBackgroundrunning interface callback mode work properly * @tc.desc:verify new stopBackgroundrunning interface callback mode work properly
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest004", 0, async function (done) { it("ContinuousTaskJsTest004", 0, async function (done) {
function conTaskCallback(err, data) { console.info(TAG + '-----------------ContinuousTaskJsTest004 begin--------------------');
if (err) { startAbilityWithOption({ events: ["stopTaskUseApi8Callback"] }, "testcase4", "stopTaskUseApi8Callback", done);
console.info('ContinuousTaskJsTest004 startBackgroundRunning failure');
expect(false).assertTrue();
} else {
console.info('ContinuousTaskJsTest004 startBackgroundRunning success');
expect(true).assertTrue();
}
setTimeout(()=>{
done();
}, 500);
}
let wantAgentInfo = {
wants: [
{
bundleName: "com.continuoustask.test",
abilityName: "com.continuoustask.test.MainAbility"
}
],
operationType: 2,
requestCode: 0,
wantAgentFlags: [3]
};
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
let basicContent = {
title: "title",
text: "text"
};
let notificationContent = {
contentType: notification.ContentType.NOTIFICATION_CONTENT_BASIC_TEXT,
normal: basicContent
};
let request = {
content: notificationContent,
wantAgent: data
}
let id = 1;
particleAbility.startBackgroundRunning(id, request, conTaskCallback);
});
}) })
/* /*
* @tc.name:ContinuousTaskJsTest005 * @tc.name:ContinuousTaskJsTest005
* @tc.desc:verify new api stopBackgroundrunning interface promise mode work properly * @tc.desc:verify old startBackgroundrunning interface promise mode work properly
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest005", 0, async function (done) { it("ContinuousTaskJsTest005", 0, async function (done) {
let wantAgentInfo = { console.info(TAG + '-----------------ContinuousTaskJsTest005 begin--------------------');
wants: [ startAbilityWithOption({ events: ["startTaskUseApi7Promise"] }, "testcase5", "startTaskUseApi7Promise", done);
{
bundleName: "com.continuoustask.test",
abilityName: "com.continuoustask.test.MainAbility"
}
],
operationType: 2,
requestCode: 0,
wantAgentFlags: [3]
};
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
backgroundTaskManager.BackgroundMode.DATA_TRANSFER, data).then((data) => {
backgroundTaskManager.stopBackgroundRunning(featureAbility.getContext()).then((data) => {
console.log("ContinuousTaskJsTest005 cancelBackgroundRunning success");
expect(true).assertTrue();
setTimeout(() => {
done();
}, 500);
}).catch((err) => {
expect(false).assertTrue();
console.log("ContinuousTaskJsTest005 cancelBackgroundRunning failure");
setTimeout(() => {
done();
}, 500);
});
})
});
}) })
/* /*
* @tc.name:ContinuousTaskJsTest006 * @tc.name:ContinuousTaskJsTest006
* @tc.desc:verify new api stopBackgroundrunning interface callback mode work properly * @tc.desc:verify cancelBackgroundrunning interface promise mode work properly
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest006", 0, async function (done) { it("ContinuousTaskJsTest006", 0, async function (done) {
function conTaskCallback(err, data) { console.info(TAG + '-----------------ContinuousTaskJsTest006 begin--------------------');
if (err) { startAbilityWithOption({ events: ["stopTaskUseApi7Promise"] }, "testcase6", "stopTaskUseApi7Promise", done);
console.info('ContinuousTaskJsTest006 startBackgroundRunning failure');
expect(false).assertTrue();
} else {
console.info('ContinuousTaskJsTest006 startBackgroundRunning success');
expect(true).assertTrue();
}
setTimeout(()=>{
done();
}, 500);
}
let wantAgentInfo = {
wants: [
{
bundleName: "com.continuoustask.test",
abilityName: "com.continuoustask.test.MainAbility"
}
],
operationType: 2,
requestCode: 0,
wantAgentFlags: [3]
};
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
backgroundTaskManager.BackgroundMode.DATA_TRANSFER, data).then((data) => {
backgroundTaskManager.stopBackgroundRunning(featureAbility.getContext(), conTaskCallback);
})
});
}) })
/* /*
* @tc.name:ContinuousTaskJsTest007 * @tc.name:ContinuousTaskJsTest007
* @tc.desc:verify old api cancelBackgroundrunning interface promise mode work properly * @tc.desc:verify new startBackgroundrunning interface promise mode work properly
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest007", 0, async function (done) { it("ContinuousTaskJsTest007", 0, async function (done) {
let wantAgentInfo = { console.info(TAG + '-----------------ContinuousTaskJsTest007 begin--------------------');
wants: [ startAbilityWithOption({ events: ["startTaskUseApi8Promise"] }, "testcase7", "startTaskUseApi8Promise", done);
{
bundleName: "com.continuoustask.test",
abilityName: "com.continuoustask.test.MainAbility"
}
],
operationType: 2,
requestCode: 0,
wantAgentFlags: [3]
};
await wantAgent.getWantAgent(wantAgentInfo).then((data) => {
particleAbility.startBackgroundRunning(data);
setTimeout(()=>{
}, 500);
});
particleAbility.cancelBackgroundRunning().then(() => {
console.log("ContinuousTaskJsTest007 cancelBackgroundRunning success");
expect(true).assertTrue();
setTimeout(() => {
done();
}, 500);
}).catch( (err) => {
expect(false).assertTrue();
console.log("ContinuousTaskJsTest007 cancelBackgroundRunning failure");
setTimeout(() => {
done();
}, 500);
});
}) })
/* /*
* @tc.name:ContinuousTaskJsTest008 * @tc.name:ContinuousTaskJsTest008
* @tc.desc:verify old cancelBackgroundrunning interface callback mode work properly * @tc.desc:verify new stopBackgroundrunning interface promise mode work properly
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest008", 0, async function (done) { it("ContinuousTaskJsTest008", 0, async function (done) {
function conTaskCallback(err, data) { console.info(TAG + '-----------------ContinuousTaskJsTest008 begin--------------------');
if (err) { startAbilityWithOption({ events: ["stopTaskUseApi8Promise"] }, "testcase8", "stopTaskUseApi8Promise", done);
console.info('ContinuousTaskJsTest008 startBackgroundRunning failure'); })
expect(false).assertTrue();
} else {
console.info('ContinuousTaskJsTest008 startBackgroundRunning success');
expect(true).assertTrue();
}
setTimeout(()=>{
done();
}, 500);
}
let wantAgentInfo = {
wants: [
{
bundleName: "com.continuoustask.test",
abilityName: "com.continuoustask.test.MainAbility"
}
],
operationType: 2,
requestCode: 0,
wantAgentFlags: [3]
};
await wantAgent.getWantAgent(wantAgentInfo).then((data) => {
particleAbility.startBackgroundRunning(data);
setTimeout(()=>{
}, 500);
});
particleAbility.cancelBackgroundRunning(conTaskCallback); /*
* @tc.name:ContinuousTaskJsTest009
* @tc.desc:verify continuous task request failed with invalid background mode
* @tc.type: FUNC
* @tc.require:
*/
it("ContinuousTaskJsTest009", 0, async function (done) {
console.info(TAG + '-----------------ContinuousTaskJsTest009 begin--------------------');
startAbilityWithOption({ events: ["startTaskInvalidBgmode"] }, "testcase9", "startTaskInvalidBgmode", done);
}) })
/* /*
...@@ -394,10 +204,10 @@ describe("ContinuousTaskJsTest", function () { ...@@ -394,10 +204,10 @@ describe("ContinuousTaskJsTest", function () {
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest009", 0, function (done) { it("ContinuousTaskJsTest010", 0, async function (done) {
console.info('----------------------ContinuousTaskJsTest009---------------------------'); console.info(TAG + '-----------------ContinuousTaskJsTest010 begin--------------------');
let value1 = backgroundTaskManager.BackgroundMode.DATA_TRANSFER; let value1 = backgroundTaskManager.BackgroundMode.DATA_TRANSFER;
expect(value1).assertEqual(1) expect(value1).assertEqual(1);
done(); done();
}) })
...@@ -407,10 +217,10 @@ describe("ContinuousTaskJsTest", function () { ...@@ -407,10 +217,10 @@ describe("ContinuousTaskJsTest", function () {
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest010", 0, function (done) { it("ContinuousTaskJsTest011", 0, async function (done) {
console.info('----------------------ContinuousTaskJsTest010---------------------------'); console.info(TAG + '-----------------ContinuousTaskJsTest011 begin--------------------');
let value1 = backgroundTaskManager.BackgroundMode.AUDIO_PLAYBACK; let value1 = backgroundTaskManager.BackgroundMode.AUDIO_PLAYBACK;
expect(value1).assertEqual(2) expect(value1).assertEqual(2);
done(); done();
}) })
...@@ -420,10 +230,10 @@ describe("ContinuousTaskJsTest", function () { ...@@ -420,10 +230,10 @@ describe("ContinuousTaskJsTest", function () {
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest011", 0, function (done) { it("ContinuousTaskJsTest012", 0, async function (done) {
console.info('----------------------ContinuousTaskJsTest011---------------------------'); console.info(TAG + '-----------------ContinuousTaskJsTest012 begin--------------------');
let value1 = backgroundTaskManager.BackgroundMode.AUDIO_RECORDING; let value1 = backgroundTaskManager.BackgroundMode.AUDIO_RECORDING;
expect(value1).assertEqual(3) expect(value1).assertEqual(3);
done(); done();
}) })
...@@ -433,10 +243,10 @@ describe("ContinuousTaskJsTest", function () { ...@@ -433,10 +243,10 @@ describe("ContinuousTaskJsTest", function () {
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest012", 0, function (done) { it("ContinuousTaskJsTest013", 0, async function (done) {
console.info('----------------------ContinuousTaskJsTest012---------------------------'); console.info(TAG + '-----------------ContinuousTaskJsTest013 begin--------------------');
let value1 = backgroundTaskManager.BackgroundMode.LOCATION; let value1 = backgroundTaskManager.BackgroundMode.LOCATION;
expect(value1).assertEqual(4) expect(value1).assertEqual(4);
done(); done();
}) })
...@@ -446,10 +256,10 @@ describe("ContinuousTaskJsTest", function () { ...@@ -446,10 +256,10 @@ describe("ContinuousTaskJsTest", function () {
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest013", 0, function (done) { it("ContinuousTaskJsTest014", 0, async function (done) {
console.info('----------------------ContinuousTaskJsTest013---------------------------'); console.info(TAG + '-----------------ContinuousTaskJsTest014 begin--------------------');
let value1 = backgroundTaskManager.BackgroundMode.BLUETOOTH_INTERACTION; let value1 = backgroundTaskManager.BackgroundMode.BLUETOOTH_INTERACTION;
expect(value1).assertEqual(5) expect(value1).assertEqual(5);
done(); done();
}) })
...@@ -459,10 +269,10 @@ describe("ContinuousTaskJsTest", function () { ...@@ -459,10 +269,10 @@ describe("ContinuousTaskJsTest", function () {
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest014", 0, function (done) { it("ContinuousTaskJsTest015", 0, async function (done) {
console.info('----------------------ContinuousTaskJsTest014---------------------------'); console.info(TAG + '-----------------ContinuousTaskJsTest015 begin--------------------');
let value1 = backgroundTaskManager.BackgroundMode.MULTI_DEVICE_CONNECTION; let value1 = backgroundTaskManager.BackgroundMode.MULTI_DEVICE_CONNECTION;
expect(value1).assertEqual(6) expect(value1).assertEqual(6);
done(); done();
}) })
...@@ -472,10 +282,10 @@ describe("ContinuousTaskJsTest", function () { ...@@ -472,10 +282,10 @@ describe("ContinuousTaskJsTest", function () {
* @tc.type: FUNC * @tc.type: FUNC
* @tc.require: * @tc.require:
*/ */
it("ContinuousTaskJsTest017", 0, function (done) { it("ContinuousTaskJsTest016", 0, async function (done) {
console.info('----------------------ContinuousTaskJsTest017---------------------------'); console.info(TAG + '-----------------ContinuousTaskJsTest016 begin--------------------');
let value1 = backgroundTaskManager.BackgroundMode.TASK_KEEPING; let value1 = backgroundTaskManager.BackgroundMode.TASK_KEEPING;
expect(value1).assertEqual(9) expect(value1).assertEqual(9);
done(); done();
}) })
}) })
\ No newline at end of file
# 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_hap("ContinuousTaskRelyHap") {
hap_profile = "./entry/src/main/config.json"
hap_name = "ContinuousTaskRelyHap"
subsystem_name = XTS_SUITENAME
final_hap_path =
"${SUITES_OUTPUT_ROOT}/${XTS_SUITENAME}/testcases/${hap_name}.hap"
testonly = true
deps = [
":hjs_demo_js_assets",
":hjs_demo_js_service_assets",
":hjs_demo_resources",
]
certificate_profile = "./signature/openharmony_sx.p7b"
}
ohos_js_assets("hjs_demo_js_assets") {
source_dir = "./entry/src/main/js/default"
}
ohos_js_assets("hjs_demo_js_service_assets") {
source_dir = "./entry/src/main/js/ServiceAbility"
}
ohos_resources("hjs_demo_resources") {
sources = [ "./entry/src/main/resources" ]
hap_profile = "./entry/src/main/config.json"
}
{
"app": {
"bundleName": "com.example.continuoustaskserver",
"vendor": "example",
"version": {
"code": 1000000,
"name": "1.0.0"
},
"apiVersion": {
"compatible": 7,
"target": 7
}
},
"deviceConfig": {},
"module": {
"package": "com.example.continuoustaskserver",
"name": ".MyApplication",
"deviceType": [
"phone"
],
"distro": {
"deliveryWithInstall": true,
"moduleName": "entry",
"moduleType": "entry",
"installationFree": false
},
"abilities": [
{
"skills": [
{
"entities": [
"entity.system.home"
],
"actions": [
"action.system.home"
]
}
],
"name": "com.example.continuoustaskserver.MainAbility",
"icon": "$media:icon",
"description": "$string:mainability_description",
"label": "$string:app_name",
"type": "page",
"visible": true,
"launchType": "standard"
},
{
"backgroundModes": [
"location"
],
"visible": true,
"srcPath": "ServiceAbility",
"name": ".ServiceAbility",
"icon": "$media:icon",
"srcLanguage": "js",
"description": "$string:description_serviceability",
"type": "service"
}
],
"js": [
{
"pages": [
"pages/index/index"
],
"name": "default",
"window": {
"designWidth": 720,
"autoDesignWidth": false
}
}
],
"reqPermissions": [
{
"name": "ohos.permission.KEEP_BACKGROUND_RUNNING"
}
]
}
}
\ No newline at end of file
/*
* Copyright (C) 2022 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 notification from '@ohos.notification';
import featureAbility from '@ohos.ability.featureAbility';
import wantAgent from '@ohos.wantAgent';
import backgroundTaskManager from '@ohos.backgroundTaskManager';
import particleAbility from '@ohos.ability.particleAbility';
import commonEvent from '@ohos.commonEvent';
const TAG = "BGMODE_TEST ";
let event;
let request = {
content: {
contentType: notification.ContentType.NOTIFICATION_CONTENT_BASIC_TEXT,
normal: {
title: "title",
text: "text"
}
},
id: 1
};
let wantAgentInfo = {
wants: [
{
bundleName: "com.example.continuoustaskserver",
abilityName: "com.example.continuoustaskserver.MainAbility"
}
],
operationType: wantAgent.OperationType.START_ABILITY,
requestCode: 0,
wantAgentFlags: [wantAgent.WantAgentFlags.UPDATE_PRESENT_FLAG]
};
function callback(err, data) {
if (err) {
console.error(TAG + " Operation failed");
} else {
console.info(TAG + " Operation succeed");
commonEvent.publish(event, (err) => {
if (err.code) {
console.error(TAG + "PublishCallBack failed");
} else {
console.info(TAG + "Publish succeed");
}
})
}
}
function startContinuousTaskUseApi7Callback() {
event = "startTaskUseApi7Callback";
particleAbility.startBackgroundRunning(1, request, callback);
}
function stopContinuousTaskUseApi7Callback() {
event = "stopTaskUseApi7Callback";
particleAbility.startBackgroundRunning(1, request).then(() => {
particleAbility.cancelBackgroundRunning(callback);
});
}
function startContinuousTaskUseApi8Callback() {
event = "startTaskUseApi8Callback";
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
backgroundTaskManager.BackgroundMode.LOCATION, data, callback);
});
}
function stopContinuousTaskUseApi8Callback() {
event = "stopTaskUseApi8Callback";
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
return backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
backgroundTaskManager.BackgroundMode.LOCATION, data);
}).then(() => {
backgroundTaskManager.stopBackgroundRunning(featureAbility.getContext(), callback);
});
}
function startContinuousTaskUseApi7Promise() {
particleAbility.startBackgroundRunning(1, request).then(() => {
commonEvent.publish("startTaskUseApi7Promise", (err) => {
if (err.code) {
console.error(TAG + "PublishCallBack failed");
} else {
console.info(TAG + "Publish succeed");
}
});
});
}
function stopContinuousTaskUseApi7Promise() {
particleAbility.startBackgroundRunning(1, request).then(() => {
return particleAbility.cancelBackgroundRunning();
}).then(() => {
commonEvent.publish("stopTaskUseApi7Promise", (err) => {
if (err.code) {
console.error(TAG + "PublishCallBack failed");
} else {
console.info(TAG + "Publish succeed");
}
});
});
}
function startContinuousTaskUseApi8Promise() {
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
return backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
backgroundTaskManager.BackgroundMode.LOCATION, data);
}).then(() => {
commonEvent.publish("startTaskUseApi8Promise", (err) => {
if (err.code) {
console.error(TAG + "PublishCallBack failed");
} else {
console.info(TAG + "Publish succeed");
}
});
});
}
function stopContinuousTaskUseApi8Promise() {
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
return backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
backgroundTaskManager.BackgroundMode.LOCATION, data);
}).then(() => {
return backgroundTaskManager.stopBackgroundRunning(featureAbility.getContext());
}).then(() => {
commonEvent.publish("stopTaskUseApi8Promise", (err) => {
if (err.code) {
console.error(TAG + "PublishCallBack failed");
} else {
console.info(TAG + "Publish succeed");
}
})
})
}
function startContinuousTaskInvalidBgmode() {
wantAgent.getWantAgent(wantAgentInfo).then((data) => {
return backgroundTaskManager.startBackgroundRunning(featureAbility.getContext(),
backgroundTaskManager.BackgroundMode.BLUETOOTH_INTERACTION, data);
}).catch(() => {
commonEvent.publish("startTaskInvalidBgmode", (err) => {
if (err.code) {
console.error(TAG + "PublishCallBack failed");
} else {
console.info(TAG + "Publish succeed");
}
});
});
}
function handleOption(want) {
switch (want.parameters.option) {
case "testcase1":
startContinuousTaskUseApi7Callback();
break;
case "testcase2":
stopContinuousTaskUseApi7Callback();
break;
case "testcase3":
startContinuousTaskUseApi8Callback();
break;
case "testcase4":
stopContinuousTaskUseApi8Callback();
break;
case "testcase5":
startContinuousTaskUseApi7Promise();
break;
case "testcase6":
stopContinuousTaskUseApi7Promise();
break;
case "testcase7":
startContinuousTaskUseApi8Promise();
break;
case "testcase8":
stopContinuousTaskUseApi8Promise();
break;
case "testcase9":
startContinuousTaskInvalidBgmode();
break;
default:
console.warn(TAG + 'Unknown option');
break;
}
}
export default {
onStart() {
console.info(TAG + 'ServiceAbility onStart');
},
onStop() {
console.info(TAG + 'ServiceAbility onStop');
},
onCommand(want, startId) {
console.info(TAG + 'ServiceAbility onCommand');
console.info(TAG + "Get onCommand want: " + JSON.stringify(want));
particleAbility.cancelBackgroundRunning();
backgroundTaskManager.stopBackgroundRunning(featureAbility.getContext());
handleOption(want);
},
onConnect(want) {
console.info(TAG + 'ServiceAbility onConnect');
},
onDisConnect(want) {
console.info(TAG + 'ServiceAbility onDisConnect');
},
};
\ No newline at end of file
/*
* 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('AceApplication onCreate');
},
onDestroy() {
console.info('AceApplication onDestroy');
}
};
{
"strings": {
"hello": "Hello",
"world": "World"
}
}
\ 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;
}
/*
* 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 {
data: {
title: ""
},
onInit() {
this.title = this.$t('strings.world');
},
onShow() {
console.info('onShow finish')
},
onReady() {
console.info('onReady');
},
}
\ No newline at end of file
{
"string": [
{
"name": "app_name",
"value": "ContinuousTaskServer"
},
{
"name": "mainability_description",
"value": "JS_Phone_Empty Feature Ability"
},
{
"name": "description_serviceability",
"value": "hap sample empty service"
}
]
}
\ No newline at end of file
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册