@learnpack/learnpack 2.1.25 → 2.1.26

Sign up to get free protection for your applications and to get access to all the features.
Files changed (182) hide show
  1. package/README.md +16 -16
  2. package/bin/run +17 -17
  3. package/bin/run.cmd +3 -3
  4. package/lib/commands/audit.d.ts +6 -6
  5. package/lib/commands/audit.js +327 -302
  6. package/lib/commands/clean.d.ts +8 -8
  7. package/lib/commands/clean.js +25 -25
  8. package/lib/commands/download.d.ts +13 -13
  9. package/lib/commands/download.js +55 -55
  10. package/lib/commands/init.d.ts +9 -9
  11. package/lib/commands/init.js +123 -123
  12. package/lib/commands/login.d.ts +14 -14
  13. package/lib/commands/login.js +37 -37
  14. package/lib/commands/logout.d.ts +14 -14
  15. package/lib/commands/logout.js +37 -37
  16. package/lib/commands/publish.d.ts +14 -14
  17. package/lib/commands/publish.js +82 -82
  18. package/lib/commands/start.d.ts +7 -7
  19. package/lib/commands/start.js +165 -165
  20. package/lib/commands/test.d.ts +6 -6
  21. package/lib/commands/test.js +62 -62
  22. package/lib/index.d.ts +1 -1
  23. package/lib/index.js +4 -4
  24. package/lib/managers/config/allowed_files.d.ts +5 -5
  25. package/lib/managers/config/allowed_files.js +30 -30
  26. package/lib/managers/config/defaults.d.ts +39 -37
  27. package/lib/managers/config/defaults.js +40 -38
  28. package/lib/managers/config/exercise.d.ts +36 -36
  29. package/lib/managers/config/exercise.js +233 -230
  30. package/lib/managers/config/index.d.ts +3 -3
  31. package/lib/managers/config/index.js +320 -302
  32. package/lib/managers/file.d.ts +13 -13
  33. package/lib/managers/file.js +134 -134
  34. package/lib/managers/gitpod.d.ts +3 -3
  35. package/lib/managers/gitpod.js +67 -67
  36. package/lib/managers/server/index.d.ts +6 -6
  37. package/lib/managers/server/index.js +58 -51
  38. package/lib/managers/server/routes.d.ts +4 -4
  39. package/lib/managers/server/routes.js +167 -167
  40. package/lib/managers/session.d.ts +3 -3
  41. package/lib/managers/session.js +104 -104
  42. package/lib/managers/socket.d.ts +3 -3
  43. package/lib/managers/socket.js +164 -164
  44. package/lib/managers/test.js +84 -84
  45. package/lib/models/action.d.ts +2 -2
  46. package/lib/models/action.js +2 -2
  47. package/lib/models/audit.d.ts +15 -15
  48. package/lib/models/audit.js +2 -2
  49. package/lib/models/config-manager.d.ts +21 -21
  50. package/lib/models/config-manager.js +2 -2
  51. package/lib/models/config.d.ts +62 -60
  52. package/lib/models/config.js +2 -2
  53. package/lib/models/counter.d.ts +11 -11
  54. package/lib/models/counter.js +2 -2
  55. package/lib/models/errors.d.ts +15 -15
  56. package/lib/models/errors.js +2 -2
  57. package/lib/models/exercise-obj.d.ts +27 -27
  58. package/lib/models/exercise-obj.js +2 -2
  59. package/lib/models/file.d.ts +5 -5
  60. package/lib/models/file.js +2 -2
  61. package/lib/models/findings.d.ts +17 -17
  62. package/lib/models/findings.js +2 -2
  63. package/lib/models/flags.d.ts +10 -10
  64. package/lib/models/flags.js +2 -2
  65. package/lib/models/front-matter.d.ts +11 -11
  66. package/lib/models/front-matter.js +2 -2
  67. package/lib/models/gitpod-data.d.ts +16 -16
  68. package/lib/models/gitpod-data.js +2 -2
  69. package/lib/models/language.d.ts +4 -4
  70. package/lib/models/language.js +2 -2
  71. package/lib/models/package.d.ts +7 -7
  72. package/lib/models/package.js +2 -2
  73. package/lib/models/plugin-config.d.ts +16 -16
  74. package/lib/models/plugin-config.js +2 -2
  75. package/lib/models/session.d.ts +23 -23
  76. package/lib/models/session.js +2 -2
  77. package/lib/models/socket.d.ts +31 -31
  78. package/lib/models/socket.js +2 -2
  79. package/lib/models/status.d.ts +1 -1
  80. package/lib/models/status.js +2 -2
  81. package/lib/models/success-types.d.ts +1 -1
  82. package/lib/models/success-types.js +2 -2
  83. package/lib/plugin/command/compile.d.ts +6 -6
  84. package/lib/plugin/command/compile.js +18 -18
  85. package/lib/plugin/command/test.d.ts +6 -6
  86. package/lib/plugin/command/test.js +25 -25
  87. package/lib/plugin/index.d.ts +27 -27
  88. package/lib/plugin/index.js +7 -7
  89. package/lib/plugin/plugin.d.ts +8 -8
  90. package/lib/plugin/plugin.js +68 -68
  91. package/lib/plugin/utils.d.ts +16 -16
  92. package/lib/plugin/utils.js +58 -58
  93. package/lib/ui/download.d.ts +5 -5
  94. package/lib/ui/download.js +61 -61
  95. package/lib/utils/BaseCommand.d.ts +8 -8
  96. package/lib/utils/BaseCommand.js +41 -41
  97. package/lib/utils/SessionCommand.d.ts +10 -10
  98. package/lib/utils/SessionCommand.js +47 -47
  99. package/lib/utils/api.d.ts +12 -12
  100. package/lib/utils/api.js +173 -173
  101. package/lib/utils/audit.d.ts +16 -16
  102. package/lib/utils/audit.js +302 -302
  103. package/lib/utils/console.d.ts +12 -12
  104. package/lib/utils/console.js +19 -19
  105. package/lib/utils/errors.d.ts +17 -17
  106. package/lib/utils/errors.js +100 -100
  107. package/lib/utils/exercisesQueue.d.ts +9 -9
  108. package/lib/utils/exercisesQueue.js +38 -38
  109. package/lib/utils/fileQueue.d.ts +40 -40
  110. package/lib/utils/fileQueue.js +168 -168
  111. package/lib/utils/misc.d.ts +1 -1
  112. package/lib/utils/misc.js +23 -23
  113. package/lib/utils/validators.d.ts +5 -5
  114. package/lib/utils/validators.js +17 -17
  115. package/lib/utils/watcher.d.ts +2 -2
  116. package/lib/utils/watcher.js +23 -23
  117. package/oclif.manifest.json +1 -1
  118. package/package.json +138 -138
  119. package/src/commands/audit.ts +25 -0
  120. package/src/commands/clean.ts +29 -29
  121. package/src/commands/download.ts +62 -62
  122. package/src/commands/login.ts +42 -42
  123. package/src/commands/logout.ts +43 -43
  124. package/src/commands/publish.ts +107 -107
  125. package/src/commands/start.ts +238 -234
  126. package/src/commands/test.ts +85 -85
  127. package/src/index.ts +1 -1
  128. package/src/managers/config/allowed_files.ts +29 -29
  129. package/src/managers/config/defaults.ts +2 -0
  130. package/src/managers/config/exercise.ts +309 -302
  131. package/src/managers/config/index.ts +22 -1
  132. package/src/managers/file.ts +169 -169
  133. package/src/managers/gitpod.ts +84 -84
  134. package/src/managers/server/index.ts +77 -69
  135. package/src/managers/session.ts +118 -118
  136. package/src/managers/socket.ts +239 -239
  137. package/src/managers/test.ts +83 -83
  138. package/src/models/action.ts +3 -3
  139. package/src/models/config-manager.ts +23 -23
  140. package/src/models/config.ts +2 -0
  141. package/src/models/counter.ts +11 -11
  142. package/src/models/errors.ts +22 -22
  143. package/src/models/file.ts +5 -5
  144. package/src/models/findings.ts +18 -18
  145. package/src/models/flags.ts +10 -10
  146. package/src/models/front-matter.ts +11 -11
  147. package/src/models/gitpod-data.ts +19 -19
  148. package/src/models/language.ts +4 -4
  149. package/src/models/package.ts +7 -7
  150. package/src/models/plugin-config.ts +17 -17
  151. package/src/models/session.ts +26 -26
  152. package/src/models/socket.ts +48 -48
  153. package/src/models/status.ts +15 -15
  154. package/src/models/success-types.ts +1 -1
  155. package/src/plugin/command/compile.ts +17 -17
  156. package/src/plugin/command/test.ts +30 -30
  157. package/src/plugin/index.ts +6 -6
  158. package/src/plugin/plugin.ts +94 -94
  159. package/src/plugin/utils.ts +87 -87
  160. package/src/types/node-fetch.d.ts +1 -1
  161. package/src/ui/download.ts +71 -71
  162. package/src/utils/BaseCommand.ts +48 -48
  163. package/src/utils/SessionCommand.ts +48 -48
  164. package/src/utils/api.ts +194 -194
  165. package/src/utils/audit.ts +395 -395
  166. package/src/utils/console.ts +24 -24
  167. package/src/utils/errors.ts +117 -117
  168. package/src/utils/exercisesQueue.ts +51 -51
  169. package/src/utils/fileQueue.ts +198 -198
  170. package/src/utils/misc.ts +23 -23
  171. package/src/utils/templates/gitignore.txt +19 -19
  172. package/src/utils/templates/incremental/.learn/exercises/01-hello-world/README.es.md +24 -24
  173. package/src/utils/templates/incremental/.learn/exercises/01-hello-world/README.md +24 -24
  174. package/src/utils/templates/incremental/README.ejs +4 -4
  175. package/src/utils/templates/incremental/README.es.ejs +4 -4
  176. package/src/utils/templates/isolated/01-hello-world/README.es.md +26 -26
  177. package/src/utils/templates/isolated/01-hello-world/README.md +26 -26
  178. package/src/utils/templates/isolated/README.ejs +4 -4
  179. package/src/utils/templates/isolated/README.es.ejs +4 -4
  180. package/src/utils/templates/no-grading/README.ejs +4 -4
  181. package/src/utils/templates/no-grading/README.es.ejs +4 -4
  182. package/src/utils/validators.ts +18 -18
@@ -1,234 +1,238 @@
1
- // import path from "path";
2
- import { flags } from "@oclif/command";
3
- import SessionCommand from "../utils/SessionCommand";
4
- import Console from "../utils/console";
5
- import socket from "../managers/socket";
6
- import queue from "../utils/fileQueue";
7
- import { decompress, downloadEditor } from "../managers/file";
8
- import { prioritizeHTMLFile } from "../utils/misc";
9
-
10
- import createServer from "../managers/server";
11
-
12
- import { IGitpodData } from "../models/gitpod-data";
13
- import { IExercise, IExerciseData } from "../models/exercise-obj";
14
-
15
- export default class StartCommand extends SessionCommand {
16
- static description = "Runs a small server with all the exercise instructions";
17
-
18
- static flags = {
19
- ...SessionCommand.flags,
20
- port: flags.string({ char: "p", description: "server port" }),
21
- host: flags.string({ char: "h", description: "server host" }),
22
- disableGrading: flags.boolean({
23
- char: "D",
24
- description: "disble grading functionality",
25
- default: false,
26
- }),
27
- // disableGrading: flags.boolean({char: 'dg', description: 'disble grading functionality', default: false }),
28
- watch: flags.boolean({
29
- char: "w",
30
- description: "Watch for file changes",
31
- default: false,
32
- }),
33
- editor: flags.string({
34
- char: "e",
35
- description: "[standalone, gitpod]",
36
- options: ["standalone", "gitpod"],
37
- }),
38
- version: flags.string({
39
- char: "v",
40
- description: "E.g: 1.0.1",
41
- default: undefined,
42
- }),
43
- grading: flags.string({
44
- char: "g",
45
- description: "[isolated, incremental]",
46
- options: ["isolated", "incremental"],
47
- }),
48
- debug: flags.boolean({
49
- char: "d",
50
- description: "debugger mode for more verbage",
51
- default: false,
52
- }),
53
- };
54
-
55
- // 🛑 IMPORTANT
56
- // Every command that will use the configManager needs this init method
57
- async init() {
58
- const { flags } = this.parse(StartCommand);
59
- await this.initSession(flags);
60
- }
61
-
62
- async run() {
63
- // get configuration object
64
- const configObject = this.configManager?.get();
65
- const config = configObject?.config;
66
-
67
- if (configObject) {
68
- const { config } = configObject;
69
-
70
- // build exerises
71
- this.configManager?.buildIndex();
72
-
73
- Console.debug(
74
- `Grading: ${config?.grading} ${
75
- config?.disabledActions?.includes("test") ? "(disabled)" : ""
76
- }, editor: ${config?.editor.mode} ${config?.editor.version}, for ${
77
- Array.isArray(configObject?.exercises) ?
78
- configObject?.exercises.length :
79
- 0
80
- } exercises found`
81
- );
82
-
83
- // download app and decompress
84
- await downloadEditor(
85
- config?.editor.version,
86
- `${config?.dirPath}/app.tar.gz`
87
- );
88
-
89
- Console.info("Decompressing LearnPack UI, this may take a minute...");
90
- await decompress(
91
- `${config?.dirPath}/app.tar.gz`,
92
- `${config?.dirPath}/_app/`
93
- );
94
-
95
- // listen to socket commands
96
- if (config && this.configManager) {
97
- const server = await createServer(configObject, this.configManager);
98
-
99
- const dispatcher = queue.dispatcher({
100
- create: true,
101
- path: `${config.dirPath}/vscode_queue.json`,
102
- });
103
-
104
- socket.start(config, server, false);
105
-
106
- socket.on("open", (data: IGitpodData) => {
107
- Console.debug("Opening these files: ", data);
108
- const files = prioritizeHTMLFile(data.files);
109
- dispatcher.enqueue(dispatcher.events.OPEN_FILES, files);
110
- socket.ready("Ready to compile...");
111
- });
112
-
113
- socket.on("open_window", (data: IGitpodData) => {
114
- Console.debug("Opening window: ", data);
115
- dispatcher.enqueue(dispatcher.events.OPEN_WINDOW, data);
116
- socket.ready("Ready to compile...");
117
- });
118
-
119
- socket.on("reset", (exercise: IExerciseData) => {
120
- try {
121
- this.configManager?.reset(exercise.exerciseSlug);
122
- dispatcher.enqueue(
123
- dispatcher.events.RESET_EXERCISE,
124
- exercise.exerciseSlug
125
- );
126
- socket.ready("Ready to compile...");
127
- } catch (error) {
128
- socket.error(
129
- "compiler-error",
130
- (error as TypeError).message ||
131
- "There was an error reseting the exercise"
132
- );
133
- setTimeout(() => socket.ready("Ready to compile..."), 2000);
134
- }
135
- });
136
- // socket.on("preview", (data) => {
137
- // Console.debug("Preview triggered, removing the 'preview' action ")
138
- // socket.removeAllowed("preview")
139
- // socket.log('ready',['Ready to compile...'])
140
- // })
141
-
142
- socket.on("build", async (data: IExerciseData) => {
143
- const exercise = this.configManager?.getExercise(data.exerciseSlug);
144
-
145
- if (!exercise?.language) {
146
- socket.error(
147
- "compiler-error",
148
- "Impossible to detect language to build for " +
149
- data.exerciseSlug +
150
- "..."
151
- );
152
- return;
153
- }
154
-
155
- socket.log(
156
- "compiling",
157
- "Building exercise " +
158
- data.exerciseSlug +
159
- " with " +
160
- exercise.language +
161
- "..."
162
- );
163
- await this.config.runHook("action", {
164
- action: "compile",
165
- socket,
166
- configuration: config,
167
- exercise,
168
- });
169
- });
170
-
171
- socket.on("test", async (data: IExerciseData) => {
172
- const exercise = this.configManager?.getExercise(data.exerciseSlug);
173
-
174
- if (!exercise?.language) {
175
- socket.error(
176
- "compiler-error",
177
- "Impossible to detect engine language for testing for " +
178
- data.exerciseSlug +
179
- "..."
180
- );
181
- return;
182
- }
183
-
184
- if (
185
- config?.disabledActions!.includes("test") ||
186
- config?.disableGrading
187
- ) {
188
- socket.ready("Grading is disabled on configuration");
189
- return true;
190
- }
191
-
192
- socket.log(
193
- "testing",
194
- "Testing your exercise using the " + exercise.language + " engine."
195
- );
196
-
197
- await this.config.runHook("action", {
198
- action: "test",
199
- socket,
200
- configuration: config,
201
- exercise,
202
- });
203
- this.configManager?.save();
204
-
205
- return true;
206
- });
207
-
208
- const terminate = () => {
209
- Console.debug("Terminating Learnpack...");
210
- server.terminate(() => {
211
- this.configManager?.noCurrentExercise();
212
- dispatcher.enqueue(dispatcher.events.END);
213
- process.exit();
214
- });
215
- };
216
-
217
- server.on("close", terminate);
218
- process.on("SIGINT", terminate);
219
- process.on("SIGTERM", terminate);
220
- process.on("SIGHUP", terminate);
221
-
222
- // finish the server startup
223
- setTimeout(() => dispatcher.enqueue(dispatcher.events.RUNNING), 1000);
224
-
225
- // start watching for file changes
226
-
227
- if (StartCommand.flags.watch)
228
- this.configManager.watchIndex(_exercises =>
229
- socket.reload(null, _exercises)
230
- );
231
- }
232
- }
233
- }
234
- }
1
+ // import path from "path";
2
+ import { flags } from "@oclif/command";
3
+ import SessionCommand from "../utils/SessionCommand";
4
+ import Console from "../utils/console";
5
+ import socket from "../managers/socket";
6
+ import queue from "../utils/fileQueue";
7
+ import { decompress, downloadEditor } from "../managers/file";
8
+ import { prioritizeHTMLFile } from "../utils/misc";
9
+
10
+ import createServer from "../managers/server";
11
+
12
+ import { IGitpodData } from "../models/gitpod-data";
13
+ import { IExercise, IExerciseData } from "../models/exercise-obj";
14
+
15
+ export default class StartCommand extends SessionCommand {
16
+ static description = "Runs a small server with all the exercise instructions";
17
+
18
+ static flags = {
19
+ ...SessionCommand.flags,
20
+ port: flags.string({ char: "p", description: "server port" }),
21
+ host: flags.string({ char: "h", description: "server host" }),
22
+ disableGrading: flags.boolean({
23
+ char: "D",
24
+ description: "disble grading functionality",
25
+ default: false,
26
+ }),
27
+ // disableGrading: flags.boolean({char: 'dg', description: 'disble grading functionality', default: false }),
28
+ watch: flags.boolean({
29
+ char: "w",
30
+ description: "Watch for file changes",
31
+ default: false,
32
+ }),
33
+ editor: flags.string({
34
+ char: "e",
35
+ description: "[standalone, gitpod]",
36
+ options: ["standalone", "gitpod"],
37
+ }),
38
+ version: flags.string({
39
+ char: "v",
40
+ description: "E.g: 1.0.1",
41
+ default: undefined,
42
+ }),
43
+ grading: flags.string({
44
+ char: "g",
45
+ description: "[isolated, incremental]",
46
+ options: ["isolated", "incremental"],
47
+ }),
48
+ debug: flags.boolean({
49
+ char: "d",
50
+ description: "debugger mode for more verbage",
51
+ default: false,
52
+ }),
53
+ };
54
+
55
+ // 🛑 IMPORTANT
56
+ // Every command that will use the configManager needs this init method
57
+ async init() {
58
+ const { flags } = this.parse(StartCommand);
59
+ await this.initSession(flags);
60
+ }
61
+
62
+ async run() {
63
+ // get configuration object
64
+ const configObject = this.configManager?.get();
65
+ const config = configObject?.config;
66
+
67
+ if (configObject) {
68
+ const { config } = configObject;
69
+
70
+ // build exerises
71
+ this.configManager?.buildIndex();
72
+
73
+ Console.debug(
74
+ `Grading: ${config?.grading} ${
75
+ config?.disabledActions?.includes("test") ? "(disabled)" : ""
76
+ }, editor: ${config?.editor.mode} ${config?.editor.version}, for ${
77
+ Array.isArray(configObject?.exercises) ?
78
+ configObject?.exercises.length :
79
+ 0
80
+ } exercises found`
81
+ );
82
+
83
+ // download app and decompress
84
+ await downloadEditor(
85
+ config?.editor.version,
86
+ `${config?.dirPath}/app.tar.gz`
87
+ );
88
+
89
+ Console.info("Decompressing LearnPack UI, this may take a minute...");
90
+ await decompress(
91
+ `${config?.dirPath}/app.tar.gz`,
92
+ `${config?.dirPath}/_app/`
93
+ );
94
+
95
+ // listen to socket commands
96
+ if (config && this.configManager) {
97
+ const server = await createServer(
98
+ configObject,
99
+ this.configManager,
100
+ process.env.NODE_ENV === "test"
101
+ );
102
+
103
+ const dispatcher = queue.dispatcher({
104
+ create: true,
105
+ path: `${config.dirPath}/vscode_queue.json`,
106
+ });
107
+
108
+ socket.start(config, server, false);
109
+
110
+ socket.on("open", (data: IGitpodData) => {
111
+ Console.debug("Opening these files: ", data);
112
+ const files = prioritizeHTMLFile(data.files);
113
+ dispatcher.enqueue(dispatcher.events.OPEN_FILES, files);
114
+ socket.ready("Ready to compile...");
115
+ });
116
+
117
+ socket.on("open_window", (data: IGitpodData) => {
118
+ Console.debug("Opening window: ", data);
119
+ dispatcher.enqueue(dispatcher.events.OPEN_WINDOW, data);
120
+ socket.ready("Ready to compile...");
121
+ });
122
+
123
+ socket.on("reset", (exercise: IExerciseData) => {
124
+ try {
125
+ this.configManager?.reset(exercise.exerciseSlug);
126
+ dispatcher.enqueue(
127
+ dispatcher.events.RESET_EXERCISE,
128
+ exercise.exerciseSlug
129
+ );
130
+ socket.ready("Ready to compile...");
131
+ } catch (error) {
132
+ socket.error(
133
+ "compiler-error",
134
+ (error as TypeError).message ||
135
+ "There was an error reseting the exercise"
136
+ );
137
+ setTimeout(() => socket.ready("Ready to compile..."), 2000);
138
+ }
139
+ });
140
+ // socket.on("preview", (data) => {
141
+ // Console.debug("Preview triggered, removing the 'preview' action ")
142
+ // socket.removeAllowed("preview")
143
+ // socket.log('ready',['Ready to compile...'])
144
+ // })
145
+
146
+ socket.on("build", async (data: IExerciseData) => {
147
+ const exercise = this.configManager?.getExercise(data.exerciseSlug);
148
+
149
+ if (!exercise?.language) {
150
+ socket.error(
151
+ "compiler-error",
152
+ "Impossible to detect language to build for " +
153
+ data.exerciseSlug +
154
+ "..."
155
+ );
156
+ return;
157
+ }
158
+
159
+ socket.log(
160
+ "compiling",
161
+ "Building exercise " +
162
+ data.exerciseSlug +
163
+ " with " +
164
+ exercise.language +
165
+ "..."
166
+ );
167
+ await this.config.runHook("action", {
168
+ action: "compile",
169
+ socket,
170
+ configuration: config,
171
+ exercise,
172
+ });
173
+ });
174
+
175
+ socket.on("test", async (data: IExerciseData) => {
176
+ const exercise = this.configManager?.getExercise(data.exerciseSlug);
177
+
178
+ if (!exercise?.language) {
179
+ socket.error(
180
+ "compiler-error",
181
+ "Impossible to detect engine language for testing for " +
182
+ data.exerciseSlug +
183
+ "..."
184
+ );
185
+ return;
186
+ }
187
+
188
+ if (
189
+ config?.disabledActions!.includes("test") ||
190
+ config?.disableGrading
191
+ ) {
192
+ socket.ready("Grading is disabled on configuration");
193
+ return true;
194
+ }
195
+
196
+ socket.log(
197
+ "testing",
198
+ "Testing your exercise using the " + exercise.language + " engine."
199
+ );
200
+
201
+ await this.config.runHook("action", {
202
+ action: "test",
203
+ socket,
204
+ configuration: config,
205
+ exercise,
206
+ });
207
+ this.configManager?.save();
208
+
209
+ return true;
210
+ });
211
+
212
+ const terminate = () => {
213
+ Console.debug("Terminating Learnpack...");
214
+ server.terminate(() => {
215
+ this.configManager?.noCurrentExercise();
216
+ dispatcher.enqueue(dispatcher.events.END);
217
+ process.exit();
218
+ });
219
+ };
220
+
221
+ server.on("close", terminate);
222
+ process.on("SIGINT", terminate);
223
+ process.on("SIGTERM", terminate);
224
+ process.on("SIGHUP", terminate);
225
+
226
+ // finish the server startup
227
+ setTimeout(() => dispatcher.enqueue(dispatcher.events.RUNNING), 1000);
228
+
229
+ // start watching for file changes
230
+
231
+ if (StartCommand.flags.watch)
232
+ this.configManager.watchIndex(_exercises =>
233
+ socket.reload(null, _exercises)
234
+ );
235
+ }
236
+ }
237
+ }
238
+ }
@@ -1,85 +1,85 @@
1
- import Console from "../utils/console";
2
- import SessionCommand from "../utils/SessionCommand";
3
- import socket from "../managers/socket";
4
-
5
- import createServer from "../managers/server";
6
- import ExercisesQueue from "../utils/exercisesQueue";
7
- import { IExercise } from "../models/exercise-obj";
8
-
9
- class TestCommand extends SessionCommand {
10
- async init() {
11
- const { flags } = this.parse(TestCommand);
12
- await this.initSession(flags);
13
- }
14
-
15
- async run() {
16
- const {
17
- args: { exerciseSlug },
18
- } = this.parse(TestCommand);
19
-
20
- // Build exercises index
21
- this.configManager?.buildIndex();
22
-
23
- let exercises: IExercise[] | undefined = [];
24
-
25
- // test all exercises
26
- !exerciseSlug ?
27
- (exercises = this.configManager?.getAllExercises()) :
28
- (exercises = [this.configManager!.getExercise(exerciseSlug)]);
29
-
30
- const exercisesQueue = new ExercisesQueue(exercises);
31
-
32
- const configObject = this.configManager?.get();
33
-
34
- let hasFailed = false;
35
- let failedTestsCount = 0;
36
- let successTestsCount = 0;
37
- const testsToRunCount = exercisesQueue.size();
38
-
39
- configObject!.config!.testingFinishedCallback = ({ result }) => {
40
- if (result === "failed") {
41
- hasFailed = true;
42
- failedTestsCount++;
43
- } else {
44
- successTestsCount++;
45
- }
46
-
47
- if (exercisesQueue.isEmpty()) {
48
- Console.info(
49
- `${testsToRunCount} test${testsToRunCount > 1 ? "s" : ""} runned`
50
- );
51
- Console.success(
52
- `${successTestsCount} test${successTestsCount > 1 ? "s" : ""} passed`
53
- );
54
- Console.error(
55
- `${failedTestsCount} test${failedTestsCount > 1 ? "s" : ""} failed`
56
- );
57
-
58
- process.exit(hasFailed ? 1 : 0);
59
- } else {
60
- exercisesQueue.pop()!.test!(this.config, config!, socket);
61
- }
62
- };
63
-
64
- const config = configObject?.config;
65
-
66
- const server = await createServer(configObject!, this.configManager!, true);
67
-
68
- socket.start(config!, server, true);
69
-
70
- exercisesQueue.pop()!.test!(this.config, config!, socket);
71
- }
72
- }
73
-
74
- TestCommand.description = `Test exercises`;
75
-
76
- TestCommand.args = [
77
- {
78
- name: "exerciseSlug",
79
- required: false,
80
- description: "The name of the exercise to test",
81
- hidden: false,
82
- },
83
- ];
84
-
85
- export default TestCommand;
1
+ import Console from "../utils/console";
2
+ import SessionCommand from "../utils/SessionCommand";
3
+ import socket from "../managers/socket";
4
+
5
+ import createServer from "../managers/server";
6
+ import ExercisesQueue from "../utils/exercisesQueue";
7
+ import { IExercise } from "../models/exercise-obj";
8
+
9
+ class TestCommand extends SessionCommand {
10
+ async init() {
11
+ const { flags } = this.parse(TestCommand);
12
+ await this.initSession(flags);
13
+ }
14
+
15
+ async run() {
16
+ const {
17
+ args: { exerciseSlug },
18
+ } = this.parse(TestCommand);
19
+
20
+ // Build exercises index
21
+ this.configManager?.buildIndex();
22
+
23
+ let exercises: IExercise[] | undefined = [];
24
+
25
+ // test all exercises
26
+ !exerciseSlug ?
27
+ (exercises = this.configManager?.getAllExercises()) :
28
+ (exercises = [this.configManager!.getExercise(exerciseSlug)]);
29
+
30
+ const exercisesQueue = new ExercisesQueue(exercises);
31
+
32
+ const configObject = this.configManager?.get();
33
+
34
+ let hasFailed = false;
35
+ let failedTestsCount = 0;
36
+ let successTestsCount = 0;
37
+ const testsToRunCount = exercisesQueue.size();
38
+
39
+ configObject!.config!.testingFinishedCallback = ({ result }) => {
40
+ if (result === "failed") {
41
+ hasFailed = true;
42
+ failedTestsCount++;
43
+ } else {
44
+ successTestsCount++;
45
+ }
46
+
47
+ if (exercisesQueue.isEmpty()) {
48
+ Console.info(
49
+ `${testsToRunCount} test${testsToRunCount > 1 ? "s" : ""} runned`
50
+ );
51
+ Console.success(
52
+ `${successTestsCount} test${successTestsCount > 1 ? "s" : ""} passed`
53
+ );
54
+ Console.error(
55
+ `${failedTestsCount} test${failedTestsCount > 1 ? "s" : ""} failed`
56
+ );
57
+
58
+ process.exit(hasFailed ? 1 : 0);
59
+ } else {
60
+ exercisesQueue.pop()!.test!(this.config, config!, socket);
61
+ }
62
+ };
63
+
64
+ const config = configObject?.config;
65
+
66
+ const server = await createServer(configObject!, this.configManager!, true);
67
+
68
+ socket.start(config!, server, true);
69
+
70
+ exercisesQueue.pop()!.test!(this.config, config!, socket);
71
+ }
72
+ }
73
+
74
+ TestCommand.description = `Test exercises`;
75
+
76
+ TestCommand.args = [
77
+ {
78
+ name: "exerciseSlug",
79
+ required: false,
80
+ description: "The name of the exercise to test",
81
+ hidden: false,
82
+ },
83
+ ];
84
+
85
+ export default TestCommand;
package/src/index.ts CHANGED
@@ -1 +1 @@
1
- export * from '@oclif/command'
1
+ export * from '@oclif/command'