@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.
Files changed (149) hide show
  1. package/.eslintignore +1 -1
  2. package/.eslintrc.js +52 -52
  3. package/APIs.js +79 -79
  4. package/CHANGELOG.md +7 -0
  5. package/LICENSE +201 -201
  6. package/bin/ares-config.js +0 -0
  7. package/bin/ares-device-info.js +30 -30
  8. package/bin/ares-device.js +0 -0
  9. package/bin/ares-generate.js +274 -274
  10. package/bin/ares-inspect.js +179 -179
  11. package/bin/ares-install.js +223 -223
  12. package/bin/ares-launch.js +0 -0
  13. package/bin/ares-log.js +258 -258
  14. package/bin/ares-novacom.js +0 -0
  15. package/bin/ares-package.js +0 -0
  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 +0 -0
  20. package/bin/ares-shell.js +132 -132
  21. package/bin/ares.js +166 -166
  22. package/files/conf/ipk.json +30 -30
  23. package/files/conf/query/query-app.json +14 -14
  24. package/files/conf/query/query-hosted.json +18 -18
  25. package/files/conf/query/query-package.json +10 -10
  26. package/files/conf/query/query-service.json +6 -6
  27. package/files/conf/webos_emul +27 -27
  28. package/files/conf-base/env/sdk-apollo.json +7 -7
  29. package/files/conf-base/env/sdk-ose.json +8 -8
  30. package/files/conf-base/env/sdk-tv.json +8 -8
  31. package/files/conf-base/profile/config-apollo.json +28 -28
  32. package/files/conf-base/profile/config-ose.json +29 -29
  33. package/files/conf-base/profile/config-tv.json +31 -31
  34. package/files/conf-base/query/query-app.json +14 -14
  35. package/files/conf-base/query/query-hosted.json +18 -18
  36. package/files/conf-base/query/query-package.json +10 -10
  37. package/files/conf-base/query/query-service.json +6 -6
  38. package/files/conf-base/template-conf/ose-templates.json +67 -67
  39. package/files/conf-base/template-conf/tv-sdk-templates.json +57 -57
  40. package/files/help/ares-device.help +109 -109
  41. package/files/help/ares-install.help +95 -95
  42. package/files/help/ares-log-pmlogd.help +84 -84
  43. package/files/help/ares-log.help +101 -101
  44. package/files/help/ares-novacom.help +68 -68
  45. package/files/help/ares-pull.help +38 -38
  46. package/files/help/ares-push.help +38 -38
  47. package/files/help/ares-server.help +44 -44
  48. package/files/help/ares-shell.help +42 -42
  49. package/files/help/ares.help +52 -52
  50. package/files/help/readme.help +23 -23
  51. package/files/schema/ApplicationDescription.schema +319 -319
  52. package/files/templates/apollo-sdk-templates/appinfo/appinfo.json +10 -10
  53. package/files/templates/apollo-sdk-templates/bootplate-web/index.html +88 -88
  54. package/files/templates/apollo-sdk-templates/hosted-webapp/index.html +13 -13
  55. package/files/templates/apollo-sdk-templates/js-service/helloclient.js +31 -31
  56. package/files/templates/apollo-sdk-templates/js-service/helloworld_webos_service.js +188 -188
  57. package/files/templates/apollo-sdk-templates/serviceinfo/package.json +11 -11
  58. package/files/templates/apollo-sdk-templates/serviceinfo/services.json +8 -8
  59. package/files/templates/ose-sdk-templates/appinfo/appinfo.json +10 -10
  60. package/files/templates/ose-sdk-templates/bootplate-web/index.html +88 -88
  61. package/files/templates/ose-sdk-templates/hosted-webapp/index.html +13 -13
  62. package/files/templates/ose-sdk-templates/icon/icon.png +0 -0
  63. package/files/templates/ose-sdk-templates/js-service/helloclient.js +31 -31
  64. package/files/templates/ose-sdk-templates/js-service/helloworld_webos_service.js +188 -188
  65. package/files/templates/ose-sdk-templates/qml-app/main.qml +68 -68
  66. package/files/templates/ose-sdk-templates/qmlappinfo/appinfo.json +10 -10
  67. package/files/templates/ose-sdk-templates/serviceinfo/package.json +11 -11
  68. package/files/templates/ose-sdk-templates/serviceinfo/services.json +8 -8
  69. package/files/templates/tv-sdk-templates/appinfo/appinfo.json +10 -10
  70. package/files/templates/tv-sdk-templates/bootplate-web/index.html +58 -58
  71. package/files/templates/tv-sdk-templates/bootplate-web/webOSTVjs-1.2.10/LICENSE-2.0.txt +202 -202
  72. package/files/templates/tv-sdk-templates/hosted-webapp/index.html +14 -14
  73. package/files/templates/tv-sdk-templates/js-service/helloworld_service.js +39 -39
  74. package/files/templates/tv-sdk-templates/packageinfo/packageinfo.json +3 -3
  75. package/files/templates/tv-sdk-templates/serviceinfo/package.json +11 -11
  76. package/files/templates/tv-sdk-templates/serviceinfo/services.json +8 -8
  77. package/files/templates/tv-sdk-templates/webicon/icon.png +0 -0
  78. package/files/templates/tv-sdk-templates/webicon/largeIcon.png +0 -0
  79. package/lib/base/ares.html +40 -40
  80. package/lib/base/cli-appdata.js +290 -290
  81. package/lib/base/cli-control.js +44 -44
  82. package/lib/base/common-tools.js +29 -29
  83. package/lib/base/error-handler.js +265 -265
  84. package/lib/base/file-watcher.js +155 -155
  85. package/lib/base/help-format.js +147 -147
  86. package/lib/base/luna.js +178 -178
  87. package/lib/base/sdkenv.js +59 -59
  88. package/lib/base/server.js +137 -137
  89. package/lib/base/version-tools.js +79 -79
  90. package/lib/device.js +1419 -1419
  91. package/lib/inspect.js +493 -493
  92. package/lib/log.js +584 -584
  93. package/lib/package.js +1 -3
  94. package/lib/pull.js +231 -231
  95. package/lib/pusher.js +210 -210
  96. package/lib/session.js +74 -74
  97. package/lib/shell.js +193 -193
  98. package/lib/tar-filter-pack.js +62 -62
  99. package/lib/util/copy.js +31 -31
  100. package/lib/util/createFileName.js +40 -40
  101. package/lib/util/eof.js +30 -30
  102. package/lib/util/json.js +63 -63
  103. package/lib/util/merge.js +14 -14
  104. package/lib/util/objclone.js +40 -40
  105. package/lib/util/spinner.js +37 -37
  106. package/npm-shrinkwrap.json +1 -1
  107. package/package.json +1 -1
  108. package/scripts/postinstall.js +24 -24
  109. package/spec/helpers/reporter.js +65 -65
  110. package/spec/jsSpecs/apiTest/generator.spec.js +372 -372
  111. package/spec/jsSpecs/apiTest/inspector.spec.js +89 -89
  112. package/spec/jsSpecs/apiTest/installer.spec.js +67 -67
  113. package/spec/jsSpecs/apiTest/launcher.spec.js +150 -150
  114. package/spec/jsSpecs/apiTest/packager.spec.js +194 -194
  115. package/spec/jsSpecs/apiTest/puller.spec.js +101 -101
  116. package/spec/jsSpecs/apiTest/pusher.spec.js +103 -103
  117. package/spec/jsSpecs/apiTest/server.spec.js +115 -115
  118. package/spec/jsSpecs/apiTest/setupDevice.spec.js +93 -93
  119. package/spec/jsSpecs/apiTest/shell.spec.js +49 -49
  120. package/spec/jsSpecs/ares-config.spec.js +88 -88
  121. package/spec/jsSpecs/ares-device.spec.js +443 -443
  122. package/spec/jsSpecs/ares-generate.spec.js +397 -397
  123. package/spec/jsSpecs/ares-inspect.spec.js +252 -252
  124. package/spec/jsSpecs/ares-install.spec.js +150 -150
  125. package/spec/jsSpecs/ares-log.spec.js +824 -824
  126. package/spec/jsSpecs/ares-novacom.spec.js +149 -149
  127. package/spec/jsSpecs/ares-pull.spec.js +157 -157
  128. package/spec/jsSpecs/ares-push.spec.js +146 -146
  129. package/spec/jsSpecs/ares-shell.spec.js +220 -220
  130. package/spec/jsSpecs/ares.spec.js +83 -83
  131. package/spec/support/jasmine.json +22 -22
  132. package/spec/tempFiles/nativeApp/auto/pkg_arm64/GLES2 +0 -0
  133. package/spec/tempFiles/nativeApp/auto/pkg_arm64/appinfo.json +9 -9
  134. package/spec/tempFiles/nativeApp/ose/pkg_arm/Hello +0 -0
  135. package/spec/tempFiles/nativeApp/ose/pkg_arm/appinfo.json +8 -8
  136. package/spec/tempFiles/nativeApp/ose/pkg_arm/package.properties +2 -2
  137. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/Hello +0 -0
  138. package/spec/tempFiles/nativeApp/oseEmul/pkg_x86/appinfo.json +9 -9
  139. package/spec/tempFiles/nativeApp/rsi/pkg_x86/GLES2 +0 -0
  140. package/spec/tempFiles/nativeApp/rsi/pkg_x86/appinfo.json +9 -9
  141. package/spec/tempFiles/sign/sign.crt +32 -32
  142. package/spec/tempFiles/sign/signPriv.key +52 -52
  143. package/spec/test_data/ares-generate.json +57 -57
  144. package/spec/test_data/ares.json +50 -50
  145. package/.vscode/c_cpp_properties.json +0 -21
  146. package/.vscode/launch.json +0 -97
  147. package/.vscode/settings.json +0 -13
  148. package/.vscode/tasks.json +0 -32
  149. package/webos-tools-cli-3.2.1.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
+ });