@webos-tools/cli 3.2.1 → 3.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintignore +1 -1
- package/.eslintrc.js +52 -52
- package/APIs.js +79 -79
- package/CHANGELOG.md +7 -0
- package/LICENSE +201 -201
- package/bin/ares-config.js +0 -0
- package/bin/ares-device-info.js +30 -30
- package/bin/ares-device.js +0 -0
- package/bin/ares-generate.js +274 -274
- package/bin/ares-inspect.js +179 -179
- package/bin/ares-install.js +223 -223
- package/bin/ares-launch.js +0 -0
- package/bin/ares-log.js +258 -258
- package/bin/ares-novacom.js +0 -0
- package/bin/ares-package.js +0 -0
- package/bin/ares-pull.js +156 -156
- package/bin/ares-push.js +155 -155
- package/bin/ares-server.js +174 -174
- package/bin/ares-setup-device.js +0 -0
- package/bin/ares-shell.js +132 -132
- package/bin/ares.js +166 -166
- package/files/conf/ipk.json +30 -30
- package/files/conf/query/query-app.json +14 -14
- package/files/conf/query/query-hosted.json +18 -18
- package/files/conf/query/query-package.json +10 -10
- package/files/conf/query/query-service.json +6 -6
- package/files/conf/webos_emul +27 -27
- package/files/conf-base/env/sdk-apollo.json +7 -7
- package/files/conf-base/env/sdk-ose.json +8 -8
- package/files/conf-base/env/sdk-tv.json +8 -8
- package/files/conf-base/profile/config-apollo.json +28 -28
- package/files/conf-base/profile/config-ose.json +29 -29
- package/files/conf-base/profile/config-tv.json +31 -31
- package/files/conf-base/query/query-app.json +14 -14
- package/files/conf-base/query/query-hosted.json +18 -18
- package/files/conf-base/query/query-package.json +10 -10
- package/files/conf-base/query/query-service.json +6 -6
- package/files/conf-base/template-conf/ose-templates.json +67 -67
- package/files/conf-base/template-conf/tv-sdk-templates.json +57 -57
- package/files/help/ares-device.help +109 -109
- package/files/help/ares-install.help +95 -95
- package/files/help/ares-log-pmlogd.help +84 -84
- package/files/help/ares-log.help +101 -101
- package/files/help/ares-novacom.help +68 -68
- package/files/help/ares-pull.help +38 -38
- package/files/help/ares-push.help +38 -38
- package/files/help/ares-server.help +44 -44
- package/files/help/ares-shell.help +42 -42
- package/files/help/ares.help +52 -52
- package/files/help/readme.help +23 -23
- package/files/schema/ApplicationDescription.schema +319 -319
- package/files/templates/apollo-sdk-templates/appinfo/appinfo.json +10 -10
- package/files/templates/apollo-sdk-templates/bootplate-web/index.html +88 -88
- package/files/templates/apollo-sdk-templates/hosted-webapp/index.html +13 -13
- package/files/templates/apollo-sdk-templates/js-service/helloclient.js +31 -31
- package/files/templates/apollo-sdk-templates/js-service/helloworld_webos_service.js +188 -188
- package/files/templates/apollo-sdk-templates/serviceinfo/package.json +11 -11
- package/files/templates/apollo-sdk-templates/serviceinfo/services.json +8 -8
- package/files/templates/ose-sdk-templates/appinfo/appinfo.json +10 -10
- package/files/templates/ose-sdk-templates/bootplate-web/index.html +88 -88
- package/files/templates/ose-sdk-templates/hosted-webapp/index.html +13 -13
- package/files/templates/ose-sdk-templates/icon/icon.png +0 -0
- package/files/templates/ose-sdk-templates/js-service/helloclient.js +31 -31
- package/files/templates/ose-sdk-templates/js-service/helloworld_webos_service.js +188 -188
- package/files/templates/ose-sdk-templates/qml-app/main.qml +68 -68
- package/files/templates/ose-sdk-templates/qmlappinfo/appinfo.json +10 -10
- package/files/templates/ose-sdk-templates/serviceinfo/package.json +11 -11
- package/files/templates/ose-sdk-templates/serviceinfo/services.json +8 -8
- package/files/templates/tv-sdk-templates/appinfo/appinfo.json +10 -10
- package/files/templates/tv-sdk-templates/bootplate-web/index.html +58 -58
- package/files/templates/tv-sdk-templates/bootplate-web/webOSTVjs-1.2.10/LICENSE-2.0.txt +202 -202
- package/files/templates/tv-sdk-templates/hosted-webapp/index.html +14 -14
- package/files/templates/tv-sdk-templates/js-service/helloworld_service.js +39 -39
- package/files/templates/tv-sdk-templates/packageinfo/packageinfo.json +3 -3
- package/files/templates/tv-sdk-templates/serviceinfo/package.json +11 -11
- package/files/templates/tv-sdk-templates/serviceinfo/services.json +8 -8
- package/files/templates/tv-sdk-templates/webicon/icon.png +0 -0
- package/files/templates/tv-sdk-templates/webicon/largeIcon.png +0 -0
- package/lib/base/ares.html +40 -40
- package/lib/base/cli-appdata.js +290 -290
- package/lib/base/cli-control.js +44 -44
- package/lib/base/common-tools.js +29 -29
- package/lib/base/error-handler.js +265 -265
- package/lib/base/file-watcher.js +155 -155
- package/lib/base/help-format.js +147 -147
- package/lib/base/luna.js +178 -178
- package/lib/base/sdkenv.js +59 -59
- package/lib/base/server.js +137 -137
- package/lib/base/version-tools.js +79 -79
- package/lib/device.js +1419 -1419
- package/lib/inspect.js +493 -493
- package/lib/log.js +584 -584
- package/lib/package.js +1 -3
- package/lib/pull.js +231 -231
- package/lib/pusher.js +210 -210
- package/lib/session.js +74 -74
- package/lib/shell.js +193 -193
- package/lib/tar-filter-pack.js +62 -62
- package/lib/util/copy.js +31 -31
- package/lib/util/createFileName.js +40 -40
- package/lib/util/eof.js +30 -30
- package/lib/util/json.js +63 -63
- package/lib/util/merge.js +14 -14
- package/lib/util/objclone.js +40 -40
- package/lib/util/spinner.js +37 -37
- package/npm-shrinkwrap.json +1 -1
- package/package.json +1 -1
- package/scripts/postinstall.js +24 -24
- package/spec/helpers/reporter.js +65 -65
- package/spec/jsSpecs/apiTest/generator.spec.js +372 -372
- package/spec/jsSpecs/apiTest/inspector.spec.js +89 -89
- package/spec/jsSpecs/apiTest/installer.spec.js +67 -67
- package/spec/jsSpecs/apiTest/launcher.spec.js +150 -150
- package/spec/jsSpecs/apiTest/packager.spec.js +194 -194
- package/spec/jsSpecs/apiTest/puller.spec.js +101 -101
- package/spec/jsSpecs/apiTest/pusher.spec.js +103 -103
- package/spec/jsSpecs/apiTest/server.spec.js +115 -115
- package/spec/jsSpecs/apiTest/setupDevice.spec.js +93 -93
- package/spec/jsSpecs/apiTest/shell.spec.js +49 -49
- package/spec/jsSpecs/ares-config.spec.js +88 -88
- package/spec/jsSpecs/ares-device.spec.js +443 -443
- package/spec/jsSpecs/ares-generate.spec.js +397 -397
- package/spec/jsSpecs/ares-inspect.spec.js +252 -252
- package/spec/jsSpecs/ares-install.spec.js +150 -150
- package/spec/jsSpecs/ares-log.spec.js +824 -824
- package/spec/jsSpecs/ares-novacom.spec.js +149 -149
- package/spec/jsSpecs/ares-pull.spec.js +157 -157
- package/spec/jsSpecs/ares-push.spec.js +146 -146
- package/spec/jsSpecs/ares-shell.spec.js +220 -220
- package/spec/jsSpecs/ares.spec.js +83 -83
- package/spec/support/jasmine.json +22 -22
- package/spec/tempFiles/nativeApp/auto/pkg_arm64/GLES2 +0 -0
- package/spec/tempFiles/nativeApp/auto/pkg_arm64/appinfo.json +9 -9
- package/spec/tempFiles/nativeApp/ose/pkg_arm/Hello +0 -0
- package/spec/tempFiles/nativeApp/ose/pkg_arm/appinfo.json +8 -8
- package/spec/tempFiles/nativeApp/ose/pkg_arm/package.properties +2 -2
- package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/Hello +0 -0
- package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/appinfo.json +9 -9
- package/spec/tempFiles/nativeApp/rsi/pkg_x86/GLES2 +0 -0
- package/spec/tempFiles/nativeApp/rsi/pkg_x86/appinfo.json +9 -9
- package/spec/tempFiles/sign/sign.crt +32 -32
- package/spec/tempFiles/sign/signPriv.key +52 -52
- package/spec/test_data/ares-generate.json +57 -57
- package/spec/test_data/ares.json +50 -50
- package/.vscode/c_cpp_properties.json +0 -21
- package/.vscode/launch.json +0 -97
- package/.vscode/settings.json +0 -13
- package/.vscode/tasks.json +0 -32
- package/webos-tools-cli-3.2.1.tgz +0 -0
|
@@ -1,443 +1,443 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2020-2024 LG Electronics Inc.
|
|
3
|
-
*
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
const exec = require('child_process').exec,
|
|
8
|
-
path = require('path'),
|
|
9
|
-
fs = require('fs'),
|
|
10
|
-
common = require('./common-spec');
|
|
11
|
-
|
|
12
|
-
const dateFileReg = new RegExp("[A-Za-z0-9]+_display[0-9]_[0-9]+_[0-9]+.png"),
|
|
13
|
-
csvFileReg = new RegExp("[0-9]+_[0-9]+.csv"),
|
|
14
|
-
csvFilePath = path.join(__dirname, "..", "tempFiles", "resource.csv");
|
|
15
|
-
|
|
16
|
-
const aresCmd = 'ares-device';
|
|
17
|
-
|
|
18
|
-
let cmd,
|
|
19
|
-
options;
|
|
20
|
-
|
|
21
|
-
beforeAll(function(done) {
|
|
22
|
-
cmd = common.makeCmd(aresCmd);
|
|
23
|
-
common.getOptions()
|
|
24
|
-
.then(function(result) {
|
|
25
|
-
options = result;
|
|
26
|
-
common.removeOutDir(csvFilePath);
|
|
27
|
-
done();
|
|
28
|
-
});
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
afterAll(function(done) {
|
|
32
|
-
common.removeOutDir(csvFilePath);
|
|
33
|
-
done();
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
describe(aresCmd + ' -v', function() {
|
|
37
|
-
it('Print help message with verbose log', function(done) {
|
|
38
|
-
exec(cmd + ' -v', function(error, stdout, stderr) {
|
|
39
|
-
if (stderr && stderr.length > 0) {
|
|
40
|
-
common.detectNodeMessage(stderr);
|
|
41
|
-
expect(stderr).toContain("verb argv");
|
|
42
|
-
}
|
|
43
|
-
expect(stdout).toContain("SYNOPSIS");
|
|
44
|
-
expect(error).toBeNull();
|
|
45
|
-
done();
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
describe(aresCmd, function() {
|
|
51
|
-
it("Add device with ares-setup-device", function(done) {
|
|
52
|
-
common.resetDeviceList()
|
|
53
|
-
.then(function() {
|
|
54
|
-
return common.addDeviceInfo();
|
|
55
|
-
}).then(function(result) {
|
|
56
|
-
expect(result).toContain(options.device);
|
|
57
|
-
done();
|
|
58
|
-
}).catch(function(err) {
|
|
59
|
-
expect(err).toContain("The specified value already exist");
|
|
60
|
-
done();
|
|
61
|
-
});
|
|
62
|
-
});
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
describe(aresCmd + ' --device-list(-D)', function() {
|
|
66
|
-
it('Show available device list', function(done) {
|
|
67
|
-
exec(cmd + ' -D', function(error, stdout, stderr) {
|
|
68
|
-
if (stderr && stderr.length > 0) {
|
|
69
|
-
common.detectNodeMessage(stderr);
|
|
70
|
-
}
|
|
71
|
-
expect(stdout).toContain(options.device);
|
|
72
|
-
expect(stdout).toContain(options.profile);
|
|
73
|
-
done();
|
|
74
|
-
});
|
|
75
|
-
});
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
describe(aresCmd, function() {
|
|
79
|
-
it('Retrieve device information', function(done) {
|
|
80
|
-
const oseKeys = ["webos_build_id","webos_imagename","webos_name","webos_release",
|
|
81
|
-
"webos_manufacturing_version", "core_os_kernel_version", "device_name",
|
|
82
|
-
"device_id", "chromium_version", "qt_version", "nodejs_versions"],
|
|
83
|
-
tvKeys = ["modelName", 'sdkVersion', 'firmwareVersion', "boardType", "otaId"];
|
|
84
|
-
let keys = oseKeys;
|
|
85
|
-
|
|
86
|
-
if (options.profile === "tv") {
|
|
87
|
-
keys = tvKeys;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
exec(cmd + ` -i ${options.device}`, function(error, stdout, stderr) {
|
|
91
|
-
if (stderr && stderr.length > 0) {
|
|
92
|
-
common.detectNodeMessage(stderr);
|
|
93
|
-
}
|
|
94
|
-
keys.forEach(function(key) {
|
|
95
|
-
expect(stdout).toContain(key);
|
|
96
|
-
});
|
|
97
|
-
done();
|
|
98
|
-
});
|
|
99
|
-
});
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
describe(aresCmd, function() {
|
|
103
|
-
it('Retrieve session information', function(done) {
|
|
104
|
-
const keys = ["sessionId", "displayId"];
|
|
105
|
-
exec(cmd + ` -se ${options.device}`, function(error, stdout, stderr) {
|
|
106
|
-
if (stderr && stderr.length > 0) {
|
|
107
|
-
common.detectNodeMessage(stderr);
|
|
108
|
-
expect(stderr).toContain("ares-device ERR! [com.webos.service.sessionmanager failure]: " +
|
|
109
|
-
"luna-send command failed <Service does not exist: com.webos.service.sessionmanager.>");
|
|
110
|
-
expect(stderr).toContain("ares-device ERR! [Tips]: This device does not support multiple sessions");
|
|
111
|
-
}
|
|
112
|
-
else {
|
|
113
|
-
keys.forEach(function(key) {
|
|
114
|
-
expect(stdout).toContain(key);
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
done();
|
|
118
|
-
});
|
|
119
|
-
});
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
describe(aresCmd, function() {
|
|
123
|
-
const installCmd = common.makeCmd('ares-install');
|
|
124
|
-
it('Install sample ipk to device with ares-install', function(done) {
|
|
125
|
-
exec(installCmd + ` ${options.ipkPath}`, function(error, stdout, stderr) {
|
|
126
|
-
if (stderr && stderr.length > 0) {
|
|
127
|
-
common.detectNodeMessage(stderr);
|
|
128
|
-
}
|
|
129
|
-
expect(stdout).toContain("Success", stderr);
|
|
130
|
-
setTimeout(function() {
|
|
131
|
-
done();
|
|
132
|
-
}, 3000);
|
|
133
|
-
});
|
|
134
|
-
});
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
describe(aresCmd, function() {
|
|
138
|
-
const launchCmd = common.makeCmd('ares-launch');
|
|
139
|
-
it('Launch sample App', function(done) {
|
|
140
|
-
exec(launchCmd + ` ${options.pkgId}`, function(error, stdout, stderr) {
|
|
141
|
-
if (stderr && stderr.length > 0) {
|
|
142
|
-
common.detectNodeMessage(stderr);
|
|
143
|
-
}
|
|
144
|
-
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
145
|
-
expect(stdout).toContain(`Launched application ${options.pkgId}`, error);
|
|
146
|
-
setTimeout(function() {
|
|
147
|
-
done();
|
|
148
|
-
}, 3000);
|
|
149
|
-
});
|
|
150
|
-
});
|
|
151
|
-
});
|
|
152
|
-
|
|
153
|
-
describe(aresCmd + ' --resource-monitor(-r)', function() {
|
|
154
|
-
afterAll(function(done) {
|
|
155
|
-
common.removeOutDir(csvFilePath);
|
|
156
|
-
done();
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
it('Print all system resource', function(done) {
|
|
160
|
-
exec(cmd + " -r", function(error, stdout, stderr) {
|
|
161
|
-
if (stderr && stderr.length > 0) {
|
|
162
|
-
common.detectNodeMessage(stderr);
|
|
163
|
-
}
|
|
164
|
-
else {
|
|
165
|
-
expect(stdout).toContain("cpu0");
|
|
166
|
-
expect(stdout).toContain("memory");
|
|
167
|
-
}
|
|
168
|
-
done();
|
|
169
|
-
});
|
|
170
|
-
});
|
|
171
|
-
|
|
172
|
-
it('Save specific csv file for all system resource', function(done) {
|
|
173
|
-
exec(cmd + ` -r -s ${csvFilePath}`, function(error, stdout, stderr) {
|
|
174
|
-
if (stderr && stderr.length > 0) {
|
|
175
|
-
common.detectNodeMessage(stderr);
|
|
176
|
-
}
|
|
177
|
-
else {
|
|
178
|
-
expect(stdout).toContain("Create");
|
|
179
|
-
expect(stdout).toContain("cpu0");
|
|
180
|
-
expect(fs.existsSync(csvFilePath)).toBe(true);
|
|
181
|
-
done();
|
|
182
|
-
}
|
|
183
|
-
});
|
|
184
|
-
});
|
|
185
|
-
|
|
186
|
-
it('Save generated csv file name for all system resource', function(done) {
|
|
187
|
-
exec(cmd + ` -r -s`, function(error, stdout, stderr) {
|
|
188
|
-
if (stderr && stderr.length > 0) {
|
|
189
|
-
common.detectNodeMessage(stderr);
|
|
190
|
-
}
|
|
191
|
-
expect(stdout).toContain("Create");
|
|
192
|
-
expect(stdout).toContain("cpu0");
|
|
193
|
-
|
|
194
|
-
const matchedFiles = stdout.match(csvFileReg),
|
|
195
|
-
generatedFile = path.join(path.resolve('.'), matchedFiles[0]);
|
|
196
|
-
|
|
197
|
-
expect(fs.existsSync(generatedFile)).toBe(true);
|
|
198
|
-
common.removeOutDir(generatedFile);
|
|
199
|
-
done();
|
|
200
|
-
});
|
|
201
|
-
});
|
|
202
|
-
|
|
203
|
-
it('Print all system resource periodically', function(done) {
|
|
204
|
-
const child = exec(cmd + " -r -t 1");
|
|
205
|
-
let stdoutData;
|
|
206
|
-
child.stdout.on('data', function(data) {
|
|
207
|
-
stdoutData += data;
|
|
208
|
-
});
|
|
209
|
-
|
|
210
|
-
child.stderr.on('data', function(data) {
|
|
211
|
-
if (data && data.length > 0) {
|
|
212
|
-
common.detectNodeMessage(data);
|
|
213
|
-
}
|
|
214
|
-
expect(data).toBeNull();
|
|
215
|
-
});
|
|
216
|
-
|
|
217
|
-
setTimeout(() => {
|
|
218
|
-
child.kill();
|
|
219
|
-
// Check the menu item count in interval result
|
|
220
|
-
const regCPU = /cpu0/g,
|
|
221
|
-
regMemory= /memory/g,
|
|
222
|
-
matchedCPU = ((stdoutData || '').match(regCPU) || []).length,
|
|
223
|
-
matchedMemory = ((stdoutData || '').match(regMemory) || []).length;
|
|
224
|
-
|
|
225
|
-
expect(matchedCPU).toBeGreaterThan(3);
|
|
226
|
-
expect(matchedMemory).toBeGreaterThan(3);
|
|
227
|
-
done();
|
|
228
|
-
}, 8000);
|
|
229
|
-
});
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
describe(aresCmd + ' --resource-monitor(-r)', function() {
|
|
233
|
-
it('Print running app resource', function(done) {
|
|
234
|
-
exec(cmd + " -r --list", function(error, stdout, stderr) {
|
|
235
|
-
if (stderr && stderr.length > 0) {
|
|
236
|
-
common.detectNodeMessage(stderr);
|
|
237
|
-
}
|
|
238
|
-
else {
|
|
239
|
-
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
240
|
-
expect(stdout).toContain(options.pkgId, error);
|
|
241
|
-
expect(stdout).toContain("PID");
|
|
242
|
-
expect(stdout).toContain("CPU");
|
|
243
|
-
expect(stdout).toContain("MEMORY");
|
|
244
|
-
}
|
|
245
|
-
done();
|
|
246
|
-
});
|
|
247
|
-
});
|
|
248
|
-
|
|
249
|
-
it('Print running app resource periodically', function(done) {
|
|
250
|
-
const child = exec(cmd + " -r --list -t 1");
|
|
251
|
-
let stdoutData;
|
|
252
|
-
child.stdout.on('data', function(data) {
|
|
253
|
-
stdoutData += data;
|
|
254
|
-
});
|
|
255
|
-
|
|
256
|
-
child.stderr.on('data', function(data) {
|
|
257
|
-
if (data && data.length > 0) {
|
|
258
|
-
common.detectNodeMessage(data);
|
|
259
|
-
}
|
|
260
|
-
expect(data).toBeNull();
|
|
261
|
-
});
|
|
262
|
-
|
|
263
|
-
setTimeout(() => {
|
|
264
|
-
child.kill();
|
|
265
|
-
const idReg = new RegExp(options.pkgId, 'g');
|
|
266
|
-
const matchedApp = ((stdoutData || '').match(idReg) || []).length;
|
|
267
|
-
expect(matchedApp).toBeGreaterThan(3);
|
|
268
|
-
done();
|
|
269
|
-
}, 8000);
|
|
270
|
-
});
|
|
271
|
-
|
|
272
|
-
it('Print specific app resource', function(done) {
|
|
273
|
-
exec(cmd + ` -r -id ${options.pkgId}`, function(error, stdout, stderr) {
|
|
274
|
-
if (stderr && stderr.length > 0) {
|
|
275
|
-
common.detectNodeMessage(stderr);
|
|
276
|
-
}
|
|
277
|
-
else {
|
|
278
|
-
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
279
|
-
expect(stdout).toContain(options.pkgId);
|
|
280
|
-
expect(stdout).toContain("PID");
|
|
281
|
-
}
|
|
282
|
-
done();
|
|
283
|
-
});
|
|
284
|
-
});
|
|
285
|
-
|
|
286
|
-
it('Save csv file for specific app resource', function(done) {
|
|
287
|
-
exec(cmd + ` -r -id ${options.pkgId} -s ${csvFilePath}`, function(error, stdout, stderr) {
|
|
288
|
-
if (stderr && stderr.length > 0) {
|
|
289
|
-
common.detectNodeMessage(stderr);
|
|
290
|
-
}
|
|
291
|
-
else {
|
|
292
|
-
expect(stdout).toContain("Create");
|
|
293
|
-
expect(stdout).toContain(options.pkgId);
|
|
294
|
-
expect(fs.existsSync(csvFilePath)).toBe(true);
|
|
295
|
-
done();
|
|
296
|
-
}
|
|
297
|
-
done();
|
|
298
|
-
});
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
it('Print specific app is not running', function(done) {
|
|
302
|
-
exec(cmd + ` -r -id com.test.app`, function(error, stdout, stderr) {
|
|
303
|
-
if (stderr && stderr.length > 0) {
|
|
304
|
-
common.detectNodeMessage(stderr);
|
|
305
|
-
}
|
|
306
|
-
else {
|
|
307
|
-
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
308
|
-
expect(stdout).toContain("<com.test.app> is not running. Please launch the app or service.");
|
|
309
|
-
}
|
|
310
|
-
done();
|
|
311
|
-
});
|
|
312
|
-
});
|
|
313
|
-
});
|
|
314
|
-
|
|
315
|
-
describe(aresCmd + ' --remove(-r)', function() {
|
|
316
|
-
const installCmd = common.makeCmd('ares-install');
|
|
317
|
-
it('Remove installed sample app', function(done) {
|
|
318
|
-
exec(installCmd + ` -r ${options.pkgId}`, function(error, stdout, stderr) {
|
|
319
|
-
if (stderr && stderr.length > 0) {
|
|
320
|
-
common.detectNodeMessage(stderr);
|
|
321
|
-
}
|
|
322
|
-
expect(stdout).toContain(`Removed package ${options.pkgId}`, stderr);
|
|
323
|
-
done();
|
|
324
|
-
});
|
|
325
|
-
});
|
|
326
|
-
});
|
|
327
|
-
|
|
328
|
-
describe(aresCmd + ' --capture-screen(-c)', function() {
|
|
329
|
-
let generatedFile = "";
|
|
330
|
-
beforeEach(function(done) {
|
|
331
|
-
generatedFile = "";
|
|
332
|
-
done();
|
|
333
|
-
});
|
|
334
|
-
afterEach(function(done) {
|
|
335
|
-
common.removeOutDir(generatedFile);
|
|
336
|
-
done();
|
|
337
|
-
});
|
|
338
|
-
|
|
339
|
-
it('Capture', function(done) {
|
|
340
|
-
if (options.profile === "tv") {
|
|
341
|
-
pending(options.skipTxt);
|
|
342
|
-
}
|
|
343
|
-
exec(cmd + ` -c`, function(error, stdout, stderr) {
|
|
344
|
-
if (stderr && stderr.length > 0) {
|
|
345
|
-
common.detectNodeMessage(stderr);
|
|
346
|
-
}
|
|
347
|
-
expect(stdout).toContain(options.device);
|
|
348
|
-
expect(stdout).toContain(new Date().getFullYear());
|
|
349
|
-
expect(stdout).toContain("display0");
|
|
350
|
-
expect(stdout).toContain(".png");
|
|
351
|
-
expect(stdout).toContain(path.resolve('.'));
|
|
352
|
-
|
|
353
|
-
const matchedFiles = stdout.match(dateFileReg);
|
|
354
|
-
|
|
355
|
-
generatedFile = path.join(path.resolve('.'), matchedFiles[0]);
|
|
356
|
-
expect(fs.existsSync(generatedFile)).toBe(true);
|
|
357
|
-
done();
|
|
358
|
-
});
|
|
359
|
-
});
|
|
360
|
-
|
|
361
|
-
it('Capture with filename', function(done) {
|
|
362
|
-
if (options.profile === "tv") {
|
|
363
|
-
pending(options.skipTxt);
|
|
364
|
-
}
|
|
365
|
-
exec(cmd + ` -c screen.jpg`, function(error, stdout, stderr) {
|
|
366
|
-
if (stderr && stderr.length > 0) {
|
|
367
|
-
common.detectNodeMessage(stderr);
|
|
368
|
-
}
|
|
369
|
-
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
370
|
-
expect(stdout).not.toContain("display0");
|
|
371
|
-
expect(stdout).toContain("screen.jpg");
|
|
372
|
-
expect(stdout).toContain(path.resolve('.'));
|
|
373
|
-
|
|
374
|
-
generatedFile = path.join(path.resolve('.'), "screen.jpg");
|
|
375
|
-
expect(fs.existsSync(generatedFile)).toBe(true);
|
|
376
|
-
done();
|
|
377
|
-
});
|
|
378
|
-
});
|
|
379
|
-
});
|
|
380
|
-
|
|
381
|
-
describe(aresCmd + ' negative TC', function() {
|
|
382
|
-
it('Monitor system resource with invalid file extensiton', function(done) {
|
|
383
|
-
exec(cmd + ` -r -s test.abc`, function(error, stdout, stderr) {
|
|
384
|
-
if (stderr && stderr.length > 0) {
|
|
385
|
-
common.detectNodeMessage(stderr);
|
|
386
|
-
expect(stderr).toContain("ares-device ERR! [Tips]: Please change the file extension to .csv");
|
|
387
|
-
}
|
|
388
|
-
done();
|
|
389
|
-
});
|
|
390
|
-
});
|
|
391
|
-
|
|
392
|
-
it('Monitor system resource with invalid destiation Path', function(done) {
|
|
393
|
-
exec(cmd + ` -r -s invalid/system.csv`, function(error, stdout, stderr) {
|
|
394
|
-
if (stderr && stderr.length > 0) {
|
|
395
|
-
common.detectNodeMessage(stderr);
|
|
396
|
-
expect(stderr).toContain("ares-device ERR! [syscall failure]: ENOENT: no such file or directory");
|
|
397
|
-
expect(stderr).toContain("ares-device ERR! [Tips]: Please check if the path is valid");
|
|
398
|
-
}
|
|
399
|
-
done();
|
|
400
|
-
});
|
|
401
|
-
});
|
|
402
|
-
|
|
403
|
-
it('Capture with invalid file format', function(done) {
|
|
404
|
-
if (options.profile === "tv") {
|
|
405
|
-
pending(options.skipTxt);
|
|
406
|
-
}
|
|
407
|
-
exec(cmd + ` -c "test.abc"`, function(error, stdout, stderr) {
|
|
408
|
-
if (stderr && stderr.length > 0) {
|
|
409
|
-
common.detectNodeMessage(stderr);
|
|
410
|
-
expect(stderr).toContain("ares-device ERR! [Tips]: Please specify the file extension(.png, .bmp or .jpg)");
|
|
411
|
-
}
|
|
412
|
-
done();
|
|
413
|
-
});
|
|
414
|
-
});
|
|
415
|
-
|
|
416
|
-
it('Capture with invalid destiation Path', function(done) {
|
|
417
|
-
if (options.profile === "tv") {
|
|
418
|
-
pending(options.skipTxt);
|
|
419
|
-
}
|
|
420
|
-
exec(cmd + ` -c invalid/screen.png`, function(error, stdout, stderr) {
|
|
421
|
-
if (stderr && stderr.length > 0) {
|
|
422
|
-
common.detectNodeMessage(stderr);
|
|
423
|
-
expect(stderr).toContain("ares-device ERR! [syscall failure]: ENOENT: no such file or directory");
|
|
424
|
-
expect(stderr).toContain("ares-device ERR! [Tips]: Please check if the path is valid");
|
|
425
|
-
}
|
|
426
|
-
done();
|
|
427
|
-
});
|
|
428
|
-
});
|
|
429
|
-
|
|
430
|
-
it('Capture with invalid display ID', function(done) {
|
|
431
|
-
if (options.profile === "tv") {
|
|
432
|
-
pending(options.skipTxt);
|
|
433
|
-
}
|
|
434
|
-
exec(cmd + ` -c --display 10`, function(error, stdout, stderr) {
|
|
435
|
-
if (stderr && stderr.length > 0) {
|
|
436
|
-
common.detectNodeMessage(stderr);
|
|
437
|
-
expect(stderr).toContain("ares-device ERR! [com.webos.surfacemanager failure]: luna-send command failed <ERR_INVALID_DISPLAY>");
|
|
438
|
-
expect(stderr).toContain("ares-device ERR! [Tips]: Please use a valid value for display id");
|
|
439
|
-
}
|
|
440
|
-
done();
|
|
441
|
-
});
|
|
442
|
-
});
|
|
443
|
-
});
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2020-2024 LG Electronics Inc.
|
|
3
|
+
*
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
const exec = require('child_process').exec,
|
|
8
|
+
path = require('path'),
|
|
9
|
+
fs = require('fs'),
|
|
10
|
+
common = require('./common-spec');
|
|
11
|
+
|
|
12
|
+
const dateFileReg = new RegExp("[A-Za-z0-9]+_display[0-9]_[0-9]+_[0-9]+.png"),
|
|
13
|
+
csvFileReg = new RegExp("[0-9]+_[0-9]+.csv"),
|
|
14
|
+
csvFilePath = path.join(__dirname, "..", "tempFiles", "resource.csv");
|
|
15
|
+
|
|
16
|
+
const aresCmd = 'ares-device';
|
|
17
|
+
|
|
18
|
+
let cmd,
|
|
19
|
+
options;
|
|
20
|
+
|
|
21
|
+
beforeAll(function(done) {
|
|
22
|
+
cmd = common.makeCmd(aresCmd);
|
|
23
|
+
common.getOptions()
|
|
24
|
+
.then(function(result) {
|
|
25
|
+
options = result;
|
|
26
|
+
common.removeOutDir(csvFilePath);
|
|
27
|
+
done();
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
afterAll(function(done) {
|
|
32
|
+
common.removeOutDir(csvFilePath);
|
|
33
|
+
done();
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
describe(aresCmd + ' -v', function() {
|
|
37
|
+
it('Print help message with verbose log', function(done) {
|
|
38
|
+
exec(cmd + ' -v', function(error, stdout, stderr) {
|
|
39
|
+
if (stderr && stderr.length > 0) {
|
|
40
|
+
common.detectNodeMessage(stderr);
|
|
41
|
+
expect(stderr).toContain("verb argv");
|
|
42
|
+
}
|
|
43
|
+
expect(stdout).toContain("SYNOPSIS");
|
|
44
|
+
expect(error).toBeNull();
|
|
45
|
+
done();
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
describe(aresCmd, function() {
|
|
51
|
+
it("Add device with ares-setup-device", function(done) {
|
|
52
|
+
common.resetDeviceList()
|
|
53
|
+
.then(function() {
|
|
54
|
+
return common.addDeviceInfo();
|
|
55
|
+
}).then(function(result) {
|
|
56
|
+
expect(result).toContain(options.device);
|
|
57
|
+
done();
|
|
58
|
+
}).catch(function(err) {
|
|
59
|
+
expect(err).toContain("The specified value already exist");
|
|
60
|
+
done();
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
describe(aresCmd + ' --device-list(-D)', function() {
|
|
66
|
+
it('Show available device list', function(done) {
|
|
67
|
+
exec(cmd + ' -D', function(error, stdout, stderr) {
|
|
68
|
+
if (stderr && stderr.length > 0) {
|
|
69
|
+
common.detectNodeMessage(stderr);
|
|
70
|
+
}
|
|
71
|
+
expect(stdout).toContain(options.device);
|
|
72
|
+
expect(stdout).toContain(options.profile);
|
|
73
|
+
done();
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
describe(aresCmd, function() {
|
|
79
|
+
it('Retrieve device information', function(done) {
|
|
80
|
+
const oseKeys = ["webos_build_id","webos_imagename","webos_name","webos_release",
|
|
81
|
+
"webos_manufacturing_version", "core_os_kernel_version", "device_name",
|
|
82
|
+
"device_id", "chromium_version", "qt_version", "nodejs_versions"],
|
|
83
|
+
tvKeys = ["modelName", 'sdkVersion', 'firmwareVersion', "boardType", "otaId"];
|
|
84
|
+
let keys = oseKeys;
|
|
85
|
+
|
|
86
|
+
if (options.profile === "tv") {
|
|
87
|
+
keys = tvKeys;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
exec(cmd + ` -i ${options.device}`, function(error, stdout, stderr) {
|
|
91
|
+
if (stderr && stderr.length > 0) {
|
|
92
|
+
common.detectNodeMessage(stderr);
|
|
93
|
+
}
|
|
94
|
+
keys.forEach(function(key) {
|
|
95
|
+
expect(stdout).toContain(key);
|
|
96
|
+
});
|
|
97
|
+
done();
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
describe(aresCmd, function() {
|
|
103
|
+
it('Retrieve session information', function(done) {
|
|
104
|
+
const keys = ["sessionId", "displayId"];
|
|
105
|
+
exec(cmd + ` -se ${options.device}`, function(error, stdout, stderr) {
|
|
106
|
+
if (stderr && stderr.length > 0) {
|
|
107
|
+
common.detectNodeMessage(stderr);
|
|
108
|
+
expect(stderr).toContain("ares-device ERR! [com.webos.service.sessionmanager failure]: " +
|
|
109
|
+
"luna-send command failed <Service does not exist: com.webos.service.sessionmanager.>");
|
|
110
|
+
expect(stderr).toContain("ares-device ERR! [Tips]: This device does not support multiple sessions");
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
keys.forEach(function(key) {
|
|
114
|
+
expect(stdout).toContain(key);
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
done();
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
describe(aresCmd, function() {
|
|
123
|
+
const installCmd = common.makeCmd('ares-install');
|
|
124
|
+
it('Install sample ipk to device with ares-install', function(done) {
|
|
125
|
+
exec(installCmd + ` ${options.ipkPath}`, function(error, stdout, stderr) {
|
|
126
|
+
if (stderr && stderr.length > 0) {
|
|
127
|
+
common.detectNodeMessage(stderr);
|
|
128
|
+
}
|
|
129
|
+
expect(stdout).toContain("Success", stderr);
|
|
130
|
+
setTimeout(function() {
|
|
131
|
+
done();
|
|
132
|
+
}, 3000);
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
describe(aresCmd, function() {
|
|
138
|
+
const launchCmd = common.makeCmd('ares-launch');
|
|
139
|
+
it('Launch sample App', function(done) {
|
|
140
|
+
exec(launchCmd + ` ${options.pkgId}`, function(error, stdout, stderr) {
|
|
141
|
+
if (stderr && stderr.length > 0) {
|
|
142
|
+
common.detectNodeMessage(stderr);
|
|
143
|
+
}
|
|
144
|
+
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
145
|
+
expect(stdout).toContain(`Launched application ${options.pkgId}`, error);
|
|
146
|
+
setTimeout(function() {
|
|
147
|
+
done();
|
|
148
|
+
}, 3000);
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
|
|
153
|
+
describe(aresCmd + ' --resource-monitor(-r)', function() {
|
|
154
|
+
afterAll(function(done) {
|
|
155
|
+
common.removeOutDir(csvFilePath);
|
|
156
|
+
done();
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
it('Print all system resource', function(done) {
|
|
160
|
+
exec(cmd + " -r", function(error, stdout, stderr) {
|
|
161
|
+
if (stderr && stderr.length > 0) {
|
|
162
|
+
common.detectNodeMessage(stderr);
|
|
163
|
+
}
|
|
164
|
+
else {
|
|
165
|
+
expect(stdout).toContain("cpu0");
|
|
166
|
+
expect(stdout).toContain("memory");
|
|
167
|
+
}
|
|
168
|
+
done();
|
|
169
|
+
});
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
it('Save specific csv file for all system resource', function(done) {
|
|
173
|
+
exec(cmd + ` -r -s ${csvFilePath}`, function(error, stdout, stderr) {
|
|
174
|
+
if (stderr && stderr.length > 0) {
|
|
175
|
+
common.detectNodeMessage(stderr);
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
expect(stdout).toContain("Create");
|
|
179
|
+
expect(stdout).toContain("cpu0");
|
|
180
|
+
expect(fs.existsSync(csvFilePath)).toBe(true);
|
|
181
|
+
done();
|
|
182
|
+
}
|
|
183
|
+
});
|
|
184
|
+
});
|
|
185
|
+
|
|
186
|
+
it('Save generated csv file name for all system resource', function(done) {
|
|
187
|
+
exec(cmd + ` -r -s`, function(error, stdout, stderr) {
|
|
188
|
+
if (stderr && stderr.length > 0) {
|
|
189
|
+
common.detectNodeMessage(stderr);
|
|
190
|
+
}
|
|
191
|
+
expect(stdout).toContain("Create");
|
|
192
|
+
expect(stdout).toContain("cpu0");
|
|
193
|
+
|
|
194
|
+
const matchedFiles = stdout.match(csvFileReg),
|
|
195
|
+
generatedFile = path.join(path.resolve('.'), matchedFiles[0]);
|
|
196
|
+
|
|
197
|
+
expect(fs.existsSync(generatedFile)).toBe(true);
|
|
198
|
+
common.removeOutDir(generatedFile);
|
|
199
|
+
done();
|
|
200
|
+
});
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
it('Print all system resource periodically', function(done) {
|
|
204
|
+
const child = exec(cmd + " -r -t 1");
|
|
205
|
+
let stdoutData;
|
|
206
|
+
child.stdout.on('data', function(data) {
|
|
207
|
+
stdoutData += data;
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
child.stderr.on('data', function(data) {
|
|
211
|
+
if (data && data.length > 0) {
|
|
212
|
+
common.detectNodeMessage(data);
|
|
213
|
+
}
|
|
214
|
+
expect(data).toBeNull();
|
|
215
|
+
});
|
|
216
|
+
|
|
217
|
+
setTimeout(() => {
|
|
218
|
+
child.kill();
|
|
219
|
+
// Check the menu item count in interval result
|
|
220
|
+
const regCPU = /cpu0/g,
|
|
221
|
+
regMemory= /memory/g,
|
|
222
|
+
matchedCPU = ((stdoutData || '').match(regCPU) || []).length,
|
|
223
|
+
matchedMemory = ((stdoutData || '').match(regMemory) || []).length;
|
|
224
|
+
|
|
225
|
+
expect(matchedCPU).toBeGreaterThan(3);
|
|
226
|
+
expect(matchedMemory).toBeGreaterThan(3);
|
|
227
|
+
done();
|
|
228
|
+
}, 8000);
|
|
229
|
+
});
|
|
230
|
+
});
|
|
231
|
+
|
|
232
|
+
describe(aresCmd + ' --resource-monitor(-r)', function() {
|
|
233
|
+
it('Print running app resource', function(done) {
|
|
234
|
+
exec(cmd + " -r --list", function(error, stdout, stderr) {
|
|
235
|
+
if (stderr && stderr.length > 0) {
|
|
236
|
+
common.detectNodeMessage(stderr);
|
|
237
|
+
}
|
|
238
|
+
else {
|
|
239
|
+
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
240
|
+
expect(stdout).toContain(options.pkgId, error);
|
|
241
|
+
expect(stdout).toContain("PID");
|
|
242
|
+
expect(stdout).toContain("CPU");
|
|
243
|
+
expect(stdout).toContain("MEMORY");
|
|
244
|
+
}
|
|
245
|
+
done();
|
|
246
|
+
});
|
|
247
|
+
});
|
|
248
|
+
|
|
249
|
+
it('Print running app resource periodically', function(done) {
|
|
250
|
+
const child = exec(cmd + " -r --list -t 1");
|
|
251
|
+
let stdoutData;
|
|
252
|
+
child.stdout.on('data', function(data) {
|
|
253
|
+
stdoutData += data;
|
|
254
|
+
});
|
|
255
|
+
|
|
256
|
+
child.stderr.on('data', function(data) {
|
|
257
|
+
if (data && data.length > 0) {
|
|
258
|
+
common.detectNodeMessage(data);
|
|
259
|
+
}
|
|
260
|
+
expect(data).toBeNull();
|
|
261
|
+
});
|
|
262
|
+
|
|
263
|
+
setTimeout(() => {
|
|
264
|
+
child.kill();
|
|
265
|
+
const idReg = new RegExp(options.pkgId, 'g');
|
|
266
|
+
const matchedApp = ((stdoutData || '').match(idReg) || []).length;
|
|
267
|
+
expect(matchedApp).toBeGreaterThan(3);
|
|
268
|
+
done();
|
|
269
|
+
}, 8000);
|
|
270
|
+
});
|
|
271
|
+
|
|
272
|
+
it('Print specific app resource', function(done) {
|
|
273
|
+
exec(cmd + ` -r -id ${options.pkgId}`, function(error, stdout, stderr) {
|
|
274
|
+
if (stderr && stderr.length > 0) {
|
|
275
|
+
common.detectNodeMessage(stderr);
|
|
276
|
+
}
|
|
277
|
+
else {
|
|
278
|
+
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
279
|
+
expect(stdout).toContain(options.pkgId);
|
|
280
|
+
expect(stdout).toContain("PID");
|
|
281
|
+
}
|
|
282
|
+
done();
|
|
283
|
+
});
|
|
284
|
+
});
|
|
285
|
+
|
|
286
|
+
it('Save csv file for specific app resource', function(done) {
|
|
287
|
+
exec(cmd + ` -r -id ${options.pkgId} -s ${csvFilePath}`, function(error, stdout, stderr) {
|
|
288
|
+
if (stderr && stderr.length > 0) {
|
|
289
|
+
common.detectNodeMessage(stderr);
|
|
290
|
+
}
|
|
291
|
+
else {
|
|
292
|
+
expect(stdout).toContain("Create");
|
|
293
|
+
expect(stdout).toContain(options.pkgId);
|
|
294
|
+
expect(fs.existsSync(csvFilePath)).toBe(true);
|
|
295
|
+
done();
|
|
296
|
+
}
|
|
297
|
+
done();
|
|
298
|
+
});
|
|
299
|
+
});
|
|
300
|
+
|
|
301
|
+
it('Print specific app is not running', function(done) {
|
|
302
|
+
exec(cmd + ` -r -id com.test.app`, function(error, stdout, stderr) {
|
|
303
|
+
if (stderr && stderr.length > 0) {
|
|
304
|
+
common.detectNodeMessage(stderr);
|
|
305
|
+
}
|
|
306
|
+
else {
|
|
307
|
+
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
308
|
+
expect(stdout).toContain("<com.test.app> is not running. Please launch the app or service.");
|
|
309
|
+
}
|
|
310
|
+
done();
|
|
311
|
+
});
|
|
312
|
+
});
|
|
313
|
+
});
|
|
314
|
+
|
|
315
|
+
describe(aresCmd + ' --remove(-r)', function() {
|
|
316
|
+
const installCmd = common.makeCmd('ares-install');
|
|
317
|
+
it('Remove installed sample app', function(done) {
|
|
318
|
+
exec(installCmd + ` -r ${options.pkgId}`, function(error, stdout, stderr) {
|
|
319
|
+
if (stderr && stderr.length > 0) {
|
|
320
|
+
common.detectNodeMessage(stderr);
|
|
321
|
+
}
|
|
322
|
+
expect(stdout).toContain(`Removed package ${options.pkgId}`, stderr);
|
|
323
|
+
done();
|
|
324
|
+
});
|
|
325
|
+
});
|
|
326
|
+
});
|
|
327
|
+
|
|
328
|
+
describe(aresCmd + ' --capture-screen(-c)', function() {
|
|
329
|
+
let generatedFile = "";
|
|
330
|
+
beforeEach(function(done) {
|
|
331
|
+
generatedFile = "";
|
|
332
|
+
done();
|
|
333
|
+
});
|
|
334
|
+
afterEach(function(done) {
|
|
335
|
+
common.removeOutDir(generatedFile);
|
|
336
|
+
done();
|
|
337
|
+
});
|
|
338
|
+
|
|
339
|
+
it('Capture', function(done) {
|
|
340
|
+
if (options.profile === "tv") {
|
|
341
|
+
pending(options.skipTxt);
|
|
342
|
+
}
|
|
343
|
+
exec(cmd + ` -c`, function(error, stdout, stderr) {
|
|
344
|
+
if (stderr && stderr.length > 0) {
|
|
345
|
+
common.detectNodeMessage(stderr);
|
|
346
|
+
}
|
|
347
|
+
expect(stdout).toContain(options.device);
|
|
348
|
+
expect(stdout).toContain(new Date().getFullYear());
|
|
349
|
+
expect(stdout).toContain("display0");
|
|
350
|
+
expect(stdout).toContain(".png");
|
|
351
|
+
expect(stdout).toContain(path.resolve('.'));
|
|
352
|
+
|
|
353
|
+
const matchedFiles = stdout.match(dateFileReg);
|
|
354
|
+
|
|
355
|
+
generatedFile = path.join(path.resolve('.'), matchedFiles[0]);
|
|
356
|
+
expect(fs.existsSync(generatedFile)).toBe(true);
|
|
357
|
+
done();
|
|
358
|
+
});
|
|
359
|
+
});
|
|
360
|
+
|
|
361
|
+
it('Capture with filename', function(done) {
|
|
362
|
+
if (options.profile === "tv") {
|
|
363
|
+
pending(options.skipTxt);
|
|
364
|
+
}
|
|
365
|
+
exec(cmd + ` -c screen.jpg`, function(error, stdout, stderr) {
|
|
366
|
+
if (stderr && stderr.length > 0) {
|
|
367
|
+
common.detectNodeMessage(stderr);
|
|
368
|
+
}
|
|
369
|
+
expect(stdout).toContain("[Info] Set target device : " + options.device);
|
|
370
|
+
expect(stdout).not.toContain("display0");
|
|
371
|
+
expect(stdout).toContain("screen.jpg");
|
|
372
|
+
expect(stdout).toContain(path.resolve('.'));
|
|
373
|
+
|
|
374
|
+
generatedFile = path.join(path.resolve('.'), "screen.jpg");
|
|
375
|
+
expect(fs.existsSync(generatedFile)).toBe(true);
|
|
376
|
+
done();
|
|
377
|
+
});
|
|
378
|
+
});
|
|
379
|
+
});
|
|
380
|
+
|
|
381
|
+
describe(aresCmd + ' negative TC', function() {
|
|
382
|
+
it('Monitor system resource with invalid file extensiton', function(done) {
|
|
383
|
+
exec(cmd + ` -r -s test.abc`, function(error, stdout, stderr) {
|
|
384
|
+
if (stderr && stderr.length > 0) {
|
|
385
|
+
common.detectNodeMessage(stderr);
|
|
386
|
+
expect(stderr).toContain("ares-device ERR! [Tips]: Please change the file extension to .csv");
|
|
387
|
+
}
|
|
388
|
+
done();
|
|
389
|
+
});
|
|
390
|
+
});
|
|
391
|
+
|
|
392
|
+
it('Monitor system resource with invalid destiation Path', function(done) {
|
|
393
|
+
exec(cmd + ` -r -s invalid/system.csv`, function(error, stdout, stderr) {
|
|
394
|
+
if (stderr && stderr.length > 0) {
|
|
395
|
+
common.detectNodeMessage(stderr);
|
|
396
|
+
expect(stderr).toContain("ares-device ERR! [syscall failure]: ENOENT: no such file or directory");
|
|
397
|
+
expect(stderr).toContain("ares-device ERR! [Tips]: Please check if the path is valid");
|
|
398
|
+
}
|
|
399
|
+
done();
|
|
400
|
+
});
|
|
401
|
+
});
|
|
402
|
+
|
|
403
|
+
it('Capture with invalid file format', function(done) {
|
|
404
|
+
if (options.profile === "tv") {
|
|
405
|
+
pending(options.skipTxt);
|
|
406
|
+
}
|
|
407
|
+
exec(cmd + ` -c "test.abc"`, function(error, stdout, stderr) {
|
|
408
|
+
if (stderr && stderr.length > 0) {
|
|
409
|
+
common.detectNodeMessage(stderr);
|
|
410
|
+
expect(stderr).toContain("ares-device ERR! [Tips]: Please specify the file extension(.png, .bmp or .jpg)");
|
|
411
|
+
}
|
|
412
|
+
done();
|
|
413
|
+
});
|
|
414
|
+
});
|
|
415
|
+
|
|
416
|
+
it('Capture with invalid destiation Path', function(done) {
|
|
417
|
+
if (options.profile === "tv") {
|
|
418
|
+
pending(options.skipTxt);
|
|
419
|
+
}
|
|
420
|
+
exec(cmd + ` -c invalid/screen.png`, function(error, stdout, stderr) {
|
|
421
|
+
if (stderr && stderr.length > 0) {
|
|
422
|
+
common.detectNodeMessage(stderr);
|
|
423
|
+
expect(stderr).toContain("ares-device ERR! [syscall failure]: ENOENT: no such file or directory");
|
|
424
|
+
expect(stderr).toContain("ares-device ERR! [Tips]: Please check if the path is valid");
|
|
425
|
+
}
|
|
426
|
+
done();
|
|
427
|
+
});
|
|
428
|
+
});
|
|
429
|
+
|
|
430
|
+
it('Capture with invalid display ID', function(done) {
|
|
431
|
+
if (options.profile === "tv") {
|
|
432
|
+
pending(options.skipTxt);
|
|
433
|
+
}
|
|
434
|
+
exec(cmd + ` -c --display 10`, function(error, stdout, stderr) {
|
|
435
|
+
if (stderr && stderr.length > 0) {
|
|
436
|
+
common.detectNodeMessage(stderr);
|
|
437
|
+
expect(stderr).toContain("ares-device ERR! [com.webos.surfacemanager failure]: luna-send command failed <ERR_INVALID_DISPLAY>");
|
|
438
|
+
expect(stderr).toContain("ares-device ERR! [Tips]: Please use a valid value for display id");
|
|
439
|
+
}
|
|
440
|
+
done();
|
|
441
|
+
});
|
|
442
|
+
});
|
|
443
|
+
});
|