@webos-tools/cli 3.2.0 → 3.2.1

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.
Files changed (152) hide show
  1. package/.eslintignore +1 -1
  2. package/.eslintrc.js +52 -52
  3. package/.vscode/c_cpp_properties.json +21 -0
  4. package/.vscode/launch.json +97 -0
  5. package/.vscode/settings.json +13 -0
  6. package/.vscode/tasks.json +32 -0
  7. package/APIs.js +79 -79
  8. package/CHANGELOG.md +11 -5
  9. package/LICENSE +201 -201
  10. package/bin/ares-config.js +1 -1
  11. package/bin/ares-device-info.js +30 -30
  12. package/bin/ares-generate.js +274 -274
  13. package/bin/ares-inspect.js +179 -179
  14. package/bin/ares-install.js +223 -223
  15. package/bin/ares-log.js +259 -259
  16. package/bin/ares-pull.js +156 -156
  17. package/bin/ares-push.js +155 -155
  18. package/bin/ares-server.js +174 -174
  19. package/bin/ares-setup-device.js +6 -10
  20. package/bin/ares-shell.js +132 -132
  21. package/bin/ares.js +166 -166
  22. package/files/conf/ares.json +1 -2
  23. package/files/conf/ipk.json +30 -30
  24. package/files/conf/novacom-devices.json +2 -2
  25. package/files/conf/query/query-app.json +14 -14
  26. package/files/conf/query/query-hosted.json +18 -18
  27. package/files/conf/query/query-package.json +10 -10
  28. package/files/conf/query/query-service.json +6 -6
  29. package/files/conf/webos_emul +27 -27
  30. package/files/conf-base/env/sdk-apollo.json +8 -8
  31. package/files/conf-base/env/sdk-ose.json +8 -8
  32. package/files/conf-base/env/sdk-tv.json +8 -8
  33. package/files/conf-base/profile/config-apollo.json +29 -29
  34. package/files/conf-base/profile/config-ose.json +29 -29
  35. package/files/conf-base/profile/config-tv.json +31 -31
  36. package/files/conf-base/query/query-app.json +14 -14
  37. package/files/conf-base/query/query-hosted.json +18 -18
  38. package/files/conf-base/query/query-package.json +10 -10
  39. package/files/conf-base/query/query-service.json +6 -6
  40. package/files/conf-base/query/signage/query-app.json +1 -1
  41. package/files/conf-base/query/signage/query-service.json +1 -1
  42. package/files/conf-base/template-conf/ose-templates.json +67 -67
  43. package/files/conf-base/template-conf/tv-sdk-templates.json +57 -57
  44. package/files/help/ares-device.help +109 -109
  45. package/files/help/ares-install.help +95 -95
  46. package/files/help/ares-launch.help +1 -1
  47. package/files/help/ares-log-pmlogd.help +84 -84
  48. package/files/help/ares-log.help +101 -101
  49. package/files/help/ares-novacom.help +68 -68
  50. package/files/help/ares-pull.help +38 -38
  51. package/files/help/ares-push.help +38 -38
  52. package/files/help/ares-server.help +44 -44
  53. package/files/help/ares-shell.help +42 -42
  54. package/files/help/ares.help +52 -52
  55. package/files/help/readme.help +23 -23
  56. package/files/schema/ApplicationDescription.schema +319 -319
  57. package/files/templates/apollo-sdk-templates/appinfo/appinfo.json +10 -10
  58. package/files/templates/apollo-sdk-templates/bootplate-web/index.html +88 -88
  59. package/files/templates/apollo-sdk-templates/hosted-webapp/index.html +13 -13
  60. package/files/templates/apollo-sdk-templates/js-service/helloclient.js +31 -31
  61. package/files/templates/apollo-sdk-templates/js-service/helloworld_webos_service.js +188 -188
  62. package/files/templates/apollo-sdk-templates/serviceinfo/package.json +11 -11
  63. package/files/templates/apollo-sdk-templates/serviceinfo/services.json +8 -8
  64. package/files/templates/ose-sdk-templates/appinfo/appinfo.json +10 -10
  65. package/files/templates/ose-sdk-templates/bootplate-web/index.html +88 -88
  66. package/files/templates/ose-sdk-templates/hosted-webapp/index.html +13 -13
  67. package/files/templates/ose-sdk-templates/js-service/helloclient.js +31 -31
  68. package/files/templates/ose-sdk-templates/js-service/helloworld_webos_service.js +188 -188
  69. package/files/templates/ose-sdk-templates/qml-app/main.qml +68 -68
  70. package/files/templates/ose-sdk-templates/qmlappinfo/appinfo.json +10 -10
  71. package/files/templates/ose-sdk-templates/serviceinfo/package.json +11 -11
  72. package/files/templates/ose-sdk-templates/serviceinfo/services.json +8 -8
  73. package/files/templates/signage-sdk-templates/Backlight_Scheduling/index.html +1 -1
  74. package/files/templates/signage-sdk-templates/Backlight_Scheduling/scheduler.js +2 -3
  75. package/files/templates/signage-sdk-templates/File_Explorer/index.html +1 -33
  76. package/files/templates/signage-sdk-templates/File_Explorer/js/Root.js +0 -9
  77. package/files/templates/tv-sdk-templates/appinfo/appinfo.json +10 -10
  78. package/files/templates/tv-sdk-templates/bootplate-web/index.html +58 -58
  79. package/files/templates/tv-sdk-templates/bootplate-web/webOSTVjs-1.2.10/LICENSE-2.0.txt +202 -202
  80. package/files/templates/tv-sdk-templates/hosted-webapp/index.html +14 -14
  81. package/files/templates/tv-sdk-templates/js-service/helloworld_service.js +39 -39
  82. package/files/templates/tv-sdk-templates/packageinfo/packageinfo.json +3 -3
  83. package/files/templates/tv-sdk-templates/serviceinfo/package.json +11 -11
  84. package/files/templates/tv-sdk-templates/serviceinfo/services.json +8 -8
  85. package/lib/base/ares.html +40 -40
  86. package/lib/base/cli-appdata.js +290 -289
  87. package/lib/base/cli-control.js +44 -44
  88. package/lib/base/common-tools.js +29 -29
  89. package/lib/base/error-handler.js +265 -265
  90. package/lib/base/file-watcher.js +155 -155
  91. package/lib/base/help-format.js +147 -147
  92. package/lib/base/luna.js +178 -178
  93. package/lib/base/novacom.js +4 -4
  94. package/lib/base/sdkenv.js +59 -59
  95. package/lib/base/server.js +137 -137
  96. package/lib/base/setup-device.js +2 -2
  97. package/lib/base/version-tools.js +79 -79
  98. package/lib/device.js +1419 -1419
  99. package/lib/generator.js +1 -1
  100. package/lib/inspect.js +493 -493
  101. package/lib/log.js +584 -584
  102. package/lib/package.js +61 -7
  103. package/lib/pull.js +231 -231
  104. package/lib/pusher.js +210 -210
  105. package/lib/session.js +74 -74
  106. package/lib/shell.js +193 -193
  107. package/lib/tar-filter-pack.js +62 -62
  108. package/lib/util/copy.js +31 -31
  109. package/lib/util/createFileName.js +40 -40
  110. package/lib/util/eof.js +30 -30
  111. package/lib/util/json.js +63 -63
  112. package/lib/util/merge.js +14 -14
  113. package/lib/util/objclone.js +40 -40
  114. package/lib/util/spinner.js +37 -37
  115. package/npm-shrinkwrap.json +2 -2
  116. package/package.json +1 -1
  117. package/scripts/postinstall.js +24 -24
  118. package/spec/helpers/reporter.js +65 -65
  119. package/spec/jsSpecs/apiTest/generator.spec.js +372 -372
  120. package/spec/jsSpecs/apiTest/inspector.spec.js +89 -89
  121. package/spec/jsSpecs/apiTest/installer.spec.js +67 -67
  122. package/spec/jsSpecs/apiTest/launcher.spec.js +150 -150
  123. package/spec/jsSpecs/apiTest/packager.spec.js +194 -194
  124. package/spec/jsSpecs/apiTest/puller.spec.js +101 -101
  125. package/spec/jsSpecs/apiTest/pusher.spec.js +103 -103
  126. package/spec/jsSpecs/apiTest/server.spec.js +115 -115
  127. package/spec/jsSpecs/apiTest/setupDevice.spec.js +93 -93
  128. package/spec/jsSpecs/apiTest/shell.spec.js +49 -49
  129. package/spec/jsSpecs/ares-config.spec.js +88 -88
  130. package/spec/jsSpecs/ares-device.spec.js +443 -443
  131. package/spec/jsSpecs/ares-generate.spec.js +397 -401
  132. package/spec/jsSpecs/ares-inspect.spec.js +252 -252
  133. package/spec/jsSpecs/ares-install.spec.js +150 -150
  134. package/spec/jsSpecs/ares-log.spec.js +824 -824
  135. package/spec/jsSpecs/ares-novacom.spec.js +149 -149
  136. package/spec/jsSpecs/ares-pull.spec.js +157 -157
  137. package/spec/jsSpecs/ares-push.spec.js +146 -146
  138. package/spec/jsSpecs/ares-setup-device.spec.js +1 -0
  139. package/spec/jsSpecs/ares-shell.spec.js +220 -220
  140. package/spec/jsSpecs/ares.spec.js +83 -83
  141. package/spec/support/jasmine.json +22 -22
  142. package/spec/tempFiles/nativeApp/auto/pkg_arm64/appinfo.json +9 -9
  143. package/spec/tempFiles/nativeApp/ose/pkg_arm/appinfo.json +8 -8
  144. package/spec/tempFiles/nativeApp/ose/pkg_arm/package.properties +2 -2
  145. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/appinfo.json +9 -9
  146. package/spec/tempFiles/nativeApp/rsi/pkg_x86/appinfo.json +9 -9
  147. package/spec/tempFiles/sign/sign.crt +32 -32
  148. package/spec/tempFiles/sign/signPriv.key +52 -52
  149. package/spec/test_data/ares-generate.json +58 -91
  150. package/spec/test_data/ares.json +50 -50
  151. package/webos-tools-cli-3.2.1.tgz +0 -0
  152. package/webos-tools-cli-3.2.0.tgz +0 -0
@@ -1,252 +1,252 @@
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
- common = require('./common-spec');
9
-
10
- const aresCmd = 'ares-inspect';
11
-
12
- let cmd,
13
- options;
14
-
15
- beforeAll(function(done) {
16
- cmd = common.makeCmd(aresCmd);
17
- common.getOptions()
18
- .then(function(result) {
19
- options = result;
20
- done();
21
- });
22
- });
23
-
24
- describe(aresCmd + ' -v', function() {
25
- it('Print help message with verbose log', function(done) {
26
- exec(cmd + ' -v', function(error, stdout, stderr) {
27
- if (stderr && stderr.length > 0) {
28
- common.detectNodeMessage(stderr);
29
- expect(stderr).toContain("verb argv");
30
- }
31
- expect(stdout).toContain("SYNOPSIS");
32
- expect(error).toBeNull();
33
- done();
34
- });
35
- });
36
- });
37
-
38
- describe(aresCmd, function() {
39
- it("Add device with ares-setup-device", function(done) {
40
- common.resetDeviceList()
41
- .then(function() {
42
- return common.addDeviceInfo();
43
- }).then(function(result) {
44
- expect(result).toContain(options.device);
45
- done();
46
- }).catch(function(err) {
47
- expect(err).toContain("The specified value already exist");
48
- done();
49
- });
50
- });
51
- });
52
-
53
- describe(aresCmd + ' --device-list(-D)', function() {
54
- it('Show available device list', function(done) {
55
- exec(cmd + ' -D', function(error, stdout, stderr) {
56
- if (stderr && stderr.length > 0) {
57
- common.detectNodeMessage(stderr);
58
- }
59
- expect(stdout).toContain(options.device, error);
60
- expect(stdout).toContain(options.profile);
61
- done();
62
- });
63
- });
64
- });
65
-
66
- describe(aresCmd, function() {
67
- it('Install sample ipk to device', function(done) {
68
- const installCmd = common.makeCmd('ares-install');
69
- exec(installCmd + ` ${options.ipkPath}`, function(error, stdout, stderr) {
70
- if (stderr && stderr.length > 0) {
71
- common.detectNodeMessage(stderr);
72
- }
73
- expect(stdout).toContain("Success", stderr);
74
- setTimeout(() => {
75
- done();
76
- }, 2000);
77
- });
78
- });
79
- });
80
-
81
- describe(aresCmd, function() {
82
- it('Run web inspector for sample app', function(done) {
83
- const child = exec(cmd + ` -a ${options.pkgId} -dp 0`);
84
- let stdoutData = "";
85
-
86
- child.stdout.on('data', function(data) {
87
- process.stdout.write(data);
88
- stdoutData += data;
89
- });
90
-
91
- child.stderr.on('data', function(data) {
92
- if (data && data.length > 0) {
93
- common.detectNodeMessage(data);
94
- }
95
- expect(data).toBeNull();
96
- });
97
-
98
- setTimeout(() => {
99
- child.kill();
100
- expect(stdoutData).toContain('Application Debugging - http://localhost');
101
- done();
102
- }, 7000);
103
- });
104
-
105
- it('Close sample App', function(done) {
106
- const launchCmd = common.makeCmd('ares-launch');
107
- exec(launchCmd + ` -c ${options.pkgId} -dp 0`, function(error, stdout, stderr) {
108
- if (stderr && stderr.length > 0) {
109
- common.detectNodeMessage(stderr);
110
- }
111
- expect(stdout).toContain(`Closed application ${options.pkgId}`, error);
112
- setTimeout(function() {
113
- done();
114
- }, 3000);
115
- });
116
- });
117
- });
118
-
119
- describe(aresCmd +' --open(-o)', function() {
120
- it('Open web inspector for sample app', function(done) {
121
- const child = exec(cmd + ` -a ${options.pkgId} -o -dp 1`);
122
- let stdoutData = "";
123
-
124
- child.stdout.on('data', function(data) {
125
- process.stdout.write(data);
126
- stdoutData += data;
127
- });
128
-
129
- child.stderr.on('data', function(data) {
130
- if (data && data.length > 0) {
131
- common.detectNodeMessage(data);
132
- }
133
- expect(data).toBeNull();
134
- });
135
-
136
- setTimeout(() => {
137
- child.kill();
138
- expect(stdoutData).toContain('Application Debugging - http://localhost');
139
- done();
140
- }, 3000);
141
- });
142
-
143
- it('Close sample App', function(done) {
144
- const launchCmd = common.makeCmd('ares-launch');
145
- exec(launchCmd + ` -c ${options.pkgId} -dp 1`, function(error, stdout, stderr) {
146
- if (stderr && stderr.length > 0) {
147
- common.detectNodeMessage(stderr);
148
- }
149
- expect(stdout).toContain(`Closed application ${options.pkgId}`, error);
150
- setTimeout(function() {
151
- done();
152
- }, 3000);
153
- });
154
- });
155
- });
156
-
157
- describe(aresCmd, function() {
158
- let stdoutData = "";
159
-
160
- it('Run Node\'s Inspector for sample Service', function(done) {
161
- const child = exec(cmd + ` -s ${options.pkgService} -dp 1`);
162
-
163
- child.stdout.on('data', function(data) {
164
- process.stdout.write(data);
165
- stdoutData += data;
166
- });
167
-
168
- child.stderr.on('data', function(data) {
169
- if (data && data.length > 0) {
170
- common.detectNodeMessage(data);
171
- }
172
- expect(data).toBeNull();
173
- });
174
-
175
- setTimeout(() => {
176
- child.kill();
177
- expect(stdoutData).toContain("[Info] Set target device : " + options.device);
178
- expect(stdoutData).toContain("Processing");
179
- expect(stdoutData).not.toContain("null");
180
- expect(stdoutData).toContain("To debug your service, set ");
181
- done();
182
- }, 10000);
183
- });
184
- });
185
-
186
- describe(aresCmd +' --open(-o)', function() {
187
- let stdoutData = "";
188
-
189
- it('Open Node\'s Inspector for sample Service', function(done) {
190
- const child = exec(cmd + ` -s ${options.pkgService} -dp 0 -o`);
191
-
192
- child.stdout.on('data', function(data) {
193
- process.stdout.write(data);
194
- stdoutData += data;
195
- });
196
-
197
- child.stderr.on('data', function(data) {
198
- if (data && data.length > 0) {
199
- common.detectNodeMessage(data);
200
- }
201
- expect(data).toBeNull();
202
- });
203
-
204
- setTimeout(() => {
205
- child.kill();
206
- expect(stdoutData).toContain("To debug your service, set ");
207
- expect(stdoutData).toContain("Cannot support \"--open option\" on platform node version 8 and later");
208
- done();
209
- }, 7000);
210
- });
211
- });
212
-
213
- describe(aresCmd, function() {
214
- it('Remove installed sample app with ares-install', function(done) {
215
- const installCmd = common.makeCmd('ares-install');
216
- exec(installCmd + ` -r ${options.pkgId}`, function(error, stdout, stderr) {
217
- if (stderr && stderr.length > 0) {
218
- common.detectNodeMessage(stderr);
219
- }
220
- expect(stdout).toContain(`Removed package ${options.pkgId}`, stderr);
221
- done();
222
- });
223
- });
224
- });
225
-
226
- describe(aresCmd + ' negative TC', function() {
227
- it("Set invalid app which is not installed", function(done) {
228
- exec(cmd + ' com.invalid.app', function(error, stdout, stderr) {
229
- if (stderr && stderr.length > 0) {
230
- common.detectNodeMessage(stderr);
231
- if (options.profile === "ose") {
232
- expect(stderr).toContain("ares-inspect ERR! [com.webos.applicationManager failure]:" +
233
- " luna-send command failed <Cannot find proper launchPoint>");
234
- expect(stderr).toContain("ares-inspect ERR! [Tips]: The app is not installed app. Please check the list by ares-install -l");
235
- } else if (options.profile === "tv") {
236
- expect(stderr).toContain("ares-inspect ERR! [com.webos.applicationManager failure]: luna-send command failed <not exist>");
237
- }
238
- }
239
- done();
240
- });
241
- });
242
-
243
- it("Set invalid service which is not installed", function(done) {
244
- exec(cmd + ' -s com.invalid.service', function(error, stdout, stderr) {
245
- if (stderr && stderr.length > 0) {
246
- common.detectNodeMessage(stderr);
247
- expect(stderr).toContain("ares-inspect ERR! [Tips]: Failed to get service installation path <com.invalid.service>");
248
- }
249
- done();
250
- });
251
- });
252
- });
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
+ common = require('./common-spec');
9
+
10
+ const aresCmd = 'ares-inspect';
11
+
12
+ let cmd,
13
+ options;
14
+
15
+ beforeAll(function(done) {
16
+ cmd = common.makeCmd(aresCmd);
17
+ common.getOptions()
18
+ .then(function(result) {
19
+ options = result;
20
+ done();
21
+ });
22
+ });
23
+
24
+ describe(aresCmd + ' -v', function() {
25
+ it('Print help message with verbose log', function(done) {
26
+ exec(cmd + ' -v', function(error, stdout, stderr) {
27
+ if (stderr && stderr.length > 0) {
28
+ common.detectNodeMessage(stderr);
29
+ expect(stderr).toContain("verb argv");
30
+ }
31
+ expect(stdout).toContain("SYNOPSIS");
32
+ expect(error).toBeNull();
33
+ done();
34
+ });
35
+ });
36
+ });
37
+
38
+ describe(aresCmd, function() {
39
+ it("Add device with ares-setup-device", function(done) {
40
+ common.resetDeviceList()
41
+ .then(function() {
42
+ return common.addDeviceInfo();
43
+ }).then(function(result) {
44
+ expect(result).toContain(options.device);
45
+ done();
46
+ }).catch(function(err) {
47
+ expect(err).toContain("The specified value already exist");
48
+ done();
49
+ });
50
+ });
51
+ });
52
+
53
+ describe(aresCmd + ' --device-list(-D)', function() {
54
+ it('Show available device list', function(done) {
55
+ exec(cmd + ' -D', function(error, stdout, stderr) {
56
+ if (stderr && stderr.length > 0) {
57
+ common.detectNodeMessage(stderr);
58
+ }
59
+ expect(stdout).toContain(options.device, error);
60
+ expect(stdout).toContain(options.profile);
61
+ done();
62
+ });
63
+ });
64
+ });
65
+
66
+ describe(aresCmd, function() {
67
+ it('Install sample ipk to device', function(done) {
68
+ const installCmd = common.makeCmd('ares-install');
69
+ exec(installCmd + ` ${options.ipkPath}`, function(error, stdout, stderr) {
70
+ if (stderr && stderr.length > 0) {
71
+ common.detectNodeMessage(stderr);
72
+ }
73
+ expect(stdout).toContain("Success", stderr);
74
+ setTimeout(() => {
75
+ done();
76
+ }, 2000);
77
+ });
78
+ });
79
+ });
80
+
81
+ describe(aresCmd, function() {
82
+ it('Run web inspector for sample app', function(done) {
83
+ const child = exec(cmd + ` -a ${options.pkgId} -dp 0`);
84
+ let stdoutData = "";
85
+
86
+ child.stdout.on('data', function(data) {
87
+ process.stdout.write(data);
88
+ stdoutData += data;
89
+ });
90
+
91
+ child.stderr.on('data', function(data) {
92
+ if (data && data.length > 0) {
93
+ common.detectNodeMessage(data);
94
+ }
95
+ expect(data).toBeNull();
96
+ });
97
+
98
+ setTimeout(() => {
99
+ child.kill();
100
+ expect(stdoutData).toContain('Application Debugging - http://localhost');
101
+ done();
102
+ }, 7000);
103
+ });
104
+
105
+ it('Close sample App', function(done) {
106
+ const launchCmd = common.makeCmd('ares-launch');
107
+ exec(launchCmd + ` -c ${options.pkgId} -dp 0`, function(error, stdout, stderr) {
108
+ if (stderr && stderr.length > 0) {
109
+ common.detectNodeMessage(stderr);
110
+ }
111
+ expect(stdout).toContain(`Closed application ${options.pkgId}`, error);
112
+ setTimeout(function() {
113
+ done();
114
+ }, 3000);
115
+ });
116
+ });
117
+ });
118
+
119
+ describe(aresCmd +' --open(-o)', function() {
120
+ it('Open web inspector for sample app', function(done) {
121
+ const child = exec(cmd + ` -a ${options.pkgId} -o -dp 1`);
122
+ let stdoutData = "";
123
+
124
+ child.stdout.on('data', function(data) {
125
+ process.stdout.write(data);
126
+ stdoutData += data;
127
+ });
128
+
129
+ child.stderr.on('data', function(data) {
130
+ if (data && data.length > 0) {
131
+ common.detectNodeMessage(data);
132
+ }
133
+ expect(data).toBeNull();
134
+ });
135
+
136
+ setTimeout(() => {
137
+ child.kill();
138
+ expect(stdoutData).toContain('Application Debugging - http://localhost');
139
+ done();
140
+ }, 3000);
141
+ });
142
+
143
+ it('Close sample App', function(done) {
144
+ const launchCmd = common.makeCmd('ares-launch');
145
+ exec(launchCmd + ` -c ${options.pkgId} -dp 1`, function(error, stdout, stderr) {
146
+ if (stderr && stderr.length > 0) {
147
+ common.detectNodeMessage(stderr);
148
+ }
149
+ expect(stdout).toContain(`Closed application ${options.pkgId}`, error);
150
+ setTimeout(function() {
151
+ done();
152
+ }, 3000);
153
+ });
154
+ });
155
+ });
156
+
157
+ describe(aresCmd, function() {
158
+ let stdoutData = "";
159
+
160
+ it('Run Node\'s Inspector for sample Service', function(done) {
161
+ const child = exec(cmd + ` -s ${options.pkgService} -dp 1`);
162
+
163
+ child.stdout.on('data', function(data) {
164
+ process.stdout.write(data);
165
+ stdoutData += data;
166
+ });
167
+
168
+ child.stderr.on('data', function(data) {
169
+ if (data && data.length > 0) {
170
+ common.detectNodeMessage(data);
171
+ }
172
+ expect(data).toBeNull();
173
+ });
174
+
175
+ setTimeout(() => {
176
+ child.kill();
177
+ expect(stdoutData).toContain("[Info] Set target device : " + options.device);
178
+ expect(stdoutData).toContain("Processing");
179
+ expect(stdoutData).not.toContain("null");
180
+ expect(stdoutData).toContain("To debug your service, set ");
181
+ done();
182
+ }, 10000);
183
+ });
184
+ });
185
+
186
+ describe(aresCmd +' --open(-o)', function() {
187
+ let stdoutData = "";
188
+
189
+ it('Open Node\'s Inspector for sample Service', function(done) {
190
+ const child = exec(cmd + ` -s ${options.pkgService} -dp 0 -o`);
191
+
192
+ child.stdout.on('data', function(data) {
193
+ process.stdout.write(data);
194
+ stdoutData += data;
195
+ });
196
+
197
+ child.stderr.on('data', function(data) {
198
+ if (data && data.length > 0) {
199
+ common.detectNodeMessage(data);
200
+ }
201
+ expect(data).toBeNull();
202
+ });
203
+
204
+ setTimeout(() => {
205
+ child.kill();
206
+ expect(stdoutData).toContain("To debug your service, set ");
207
+ expect(stdoutData).toContain("Cannot support \"--open option\" on platform node version 8 and later");
208
+ done();
209
+ }, 7000);
210
+ });
211
+ });
212
+
213
+ describe(aresCmd, function() {
214
+ it('Remove installed sample app with ares-install', function(done) {
215
+ const installCmd = common.makeCmd('ares-install');
216
+ exec(installCmd + ` -r ${options.pkgId}`, function(error, stdout, stderr) {
217
+ if (stderr && stderr.length > 0) {
218
+ common.detectNodeMessage(stderr);
219
+ }
220
+ expect(stdout).toContain(`Removed package ${options.pkgId}`, stderr);
221
+ done();
222
+ });
223
+ });
224
+ });
225
+
226
+ describe(aresCmd + ' negative TC', function() {
227
+ it("Set invalid app which is not installed", function(done) {
228
+ exec(cmd + ' com.invalid.app', function(error, stdout, stderr) {
229
+ if (stderr && stderr.length > 0) {
230
+ common.detectNodeMessage(stderr);
231
+ if (options.profile === "ose") {
232
+ expect(stderr).toContain("ares-inspect ERR! [com.webos.applicationManager failure]:" +
233
+ " luna-send command failed <Cannot find proper launchPoint>");
234
+ expect(stderr).toContain("ares-inspect ERR! [Tips]: The app is not installed app. Please check the list by ares-install -l");
235
+ } else if (options.profile === "tv") {
236
+ expect(stderr).toContain("ares-inspect ERR! [com.webos.applicationManager failure]: luna-send command failed <not exist>");
237
+ }
238
+ }
239
+ done();
240
+ });
241
+ });
242
+
243
+ it("Set invalid service which is not installed", function(done) {
244
+ exec(cmd + ' -s com.invalid.service', function(error, stdout, stderr) {
245
+ if (stderr && stderr.length > 0) {
246
+ common.detectNodeMessage(stderr);
247
+ expect(stderr).toContain("ares-inspect ERR! [Tips]: Failed to get service installation path <com.invalid.service>");
248
+ }
249
+ done();
250
+ });
251
+ });
252
+ });