print-label.js 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. /**
  2. * @author Toru Nagashima
  3. * @copyright 2016 Toru Nagashima. All rights reserved.
  4. * See LICENSE file in root directory for full license.
  5. */
  6. 'use strict'
  7. // ------------------------------------------------------------------------------
  8. // Requirements
  9. // ------------------------------------------------------------------------------
  10. const assert = require('assert').strict
  11. const nodeApi = require('../lib')
  12. const BufferStream = require('./lib/buffer-stream')
  13. const util = require('./lib/util')
  14. const runAll = util.runAll
  15. const runPar = util.runPar
  16. const runSeq = util.runSeq
  17. // ------------------------------------------------------------------------------
  18. // Test
  19. // ------------------------------------------------------------------------------
  20. describe('[print-label] npm-run-all', () => {
  21. before(() => process.chdir('test-workspace'))
  22. after(() => process.chdir('..'))
  23. describe('should print labels at the head of every line:', () => {
  24. const EXPECTED_TEXT = [
  25. '[test-task:echo abc] abcabc',
  26. '[test-task:echo abc] abc',
  27. '[test-task:echo abc] abcabc',
  28. '[test-task:echo abc] abc',
  29. '[test-task:echo abc] abc',
  30. '[test-task:echo abc] abc',
  31. '[test-task:echo abc] abc',
  32. '[test-task:echo abc] abc',
  33. '[test-task:echo abc] ',
  34. '[test-task:echo abc] abc',
  35. '[test-task:echo abc] abcabc',
  36. '[test-task:echo abc] ',
  37. '[test-task:echo abc] ',
  38. '[test-task:echo abc] ',
  39. '[test-task:echo abc] abc',
  40. ].join('\n')
  41. it('Node API', async () => {
  42. const stdout = new BufferStream()
  43. await nodeApi('test-task:echo abc', { stdout, silent: true, printLabel: true })
  44. assert.equal(stdout.value, EXPECTED_TEXT)
  45. })
  46. it('npm-run-all command (--print-label)', async () => {
  47. const stdout = new BufferStream()
  48. await runAll(['test-task:echo abc', '--silent', '--print-label'], stdout)
  49. assert.equal(stdout.value, EXPECTED_TEXT)
  50. })
  51. it('run-s command (--print-label)', async () => {
  52. const stdout = new BufferStream()
  53. await runSeq(['test-task:echo abc', '--silent', '--print-label'], stdout)
  54. assert.equal(stdout.value, EXPECTED_TEXT)
  55. })
  56. it('run-p command (--print-label)', async () => {
  57. const stdout = new BufferStream()
  58. await runPar(['test-task:echo abc', '--silent', '--print-label'], stdout)
  59. assert.equal(stdout.value, EXPECTED_TEXT)
  60. })
  61. it('npm-run-all command (-l)', async () => {
  62. const stdout = new BufferStream()
  63. await runAll(['test-task:echo abc', '--silent', '-l'], stdout)
  64. assert.equal(stdout.value, EXPECTED_TEXT)
  65. })
  66. it('run-s command (-l)', async () => {
  67. const stdout = new BufferStream()
  68. await runSeq(['test-task:echo abc', '--silent', '-l'], stdout)
  69. assert.equal(stdout.value, EXPECTED_TEXT)
  70. })
  71. it('run-p command (-l)', async () => {
  72. const stdout = new BufferStream()
  73. await runPar(['test-task:echo abc', '--silent', '-l'], stdout)
  74. assert.equal(stdout.value, EXPECTED_TEXT)
  75. })
  76. })
  77. describe('should print all labels with the same width:', () => {
  78. const EXPECTED_TEXT = [
  79. '[test-task:echo a ] aa',
  80. '[test-task:echo a ] a',
  81. '[test-task:echo a ] aa',
  82. '[test-task:echo a ] a',
  83. '[test-task:echo a ] a',
  84. '[test-task:echo a ] a',
  85. '[test-task:echo a ] a',
  86. '[test-task:echo a ] a',
  87. '[test-task:echo a ] ',
  88. '[test-task:echo a ] a',
  89. '[test-task:echo a ] aa',
  90. '[test-task:echo a ] ',
  91. '[test-task:echo a ] ',
  92. '[test-task:echo a ] ',
  93. '[test-task:echo a ] a',
  94. '[test-task:echo abcd] abcdabcd',
  95. '[test-task:echo abcd] abcd',
  96. '[test-task:echo abcd] abcdabcd',
  97. '[test-task:echo abcd] abcd',
  98. '[test-task:echo abcd] abcd',
  99. '[test-task:echo abcd] abcd',
  100. '[test-task:echo abcd] abcd',
  101. '[test-task:echo abcd] abcd',
  102. '[test-task:echo abcd] ',
  103. '[test-task:echo abcd] abcd',
  104. '[test-task:echo abcd] abcdabcd',
  105. '[test-task:echo abcd] ',
  106. '[test-task:echo abcd] ',
  107. '[test-task:echo abcd] ',
  108. '[test-task:echo abcd] abcd',
  109. '[test-task:echo ab ] abab',
  110. '[test-task:echo ab ] ab',
  111. '[test-task:echo ab ] abab',
  112. '[test-task:echo ab ] ab',
  113. '[test-task:echo ab ] ab',
  114. '[test-task:echo ab ] ab',
  115. '[test-task:echo ab ] ab',
  116. '[test-task:echo ab ] ab',
  117. '[test-task:echo ab ] ',
  118. '[test-task:echo ab ] ab',
  119. '[test-task:echo ab ] abab',
  120. '[test-task:echo ab ] ',
  121. '[test-task:echo ab ] ',
  122. '[test-task:echo ab ] ',
  123. '[test-task:echo ab ] ab',
  124. ].join('\n')
  125. it('Node API', async () => {
  126. const stdout = new BufferStream()
  127. await nodeApi(
  128. ['test-task:echo a', 'test-task:echo abcd', 'test-task:echo ab'],
  129. { stdout, silent: true, printLabel: true }
  130. )
  131. assert.equal(stdout.value, EXPECTED_TEXT)
  132. })
  133. it('npm-run-all command', async () => {
  134. const stdout = new BufferStream()
  135. await runAll(
  136. ['test-task:echo a', 'test-task:echo abcd', 'test-task:echo ab', '--silent', '--print-label'],
  137. stdout
  138. )
  139. assert.equal(stdout.value, EXPECTED_TEXT)
  140. })
  141. it('run-s command', async () => {
  142. const stdout = new BufferStream()
  143. await runSeq(
  144. ['test-task:echo a', 'test-task:echo abcd', 'test-task:echo ab', '--silent', '--print-label'],
  145. stdout
  146. )
  147. assert.equal(stdout.value, EXPECTED_TEXT)
  148. })
  149. })
  150. describe('should work printing labels in parallel:', () => {
  151. const EXPECTED_LINES = [
  152. '\n[test-task:echo a ] ',
  153. '\n[test-task:echo a ] a',
  154. '\n[test-task:echo ab ] ',
  155. '\n[test-task:echo ab ] ab',
  156. '\n[test-task:echo abcd] ',
  157. '\n[test-task:echo abcd] abcd',
  158. ]
  159. const UNEXPECTED_PATTERNS = [
  160. /aab(cd)?/,
  161. /ab(cd)?a\b/,
  162. /\n\n/,
  163. ]
  164. it('Node API', async () => {
  165. const stdout = new BufferStream()
  166. await nodeApi(
  167. ['test-task:echo a', 'test-task:echo abcd', 'test-task:echo ab'],
  168. { stdout, parallel: true, printLabel: true }
  169. )
  170. for (const line of EXPECTED_LINES) {
  171. assert(stdout.value.indexOf(line) !== -1)
  172. }
  173. for (const pattern of UNEXPECTED_PATTERNS) {
  174. assert(!pattern.test(stdout.value))
  175. }
  176. })
  177. it('npm-run-all command', async () => {
  178. const stdout = new BufferStream()
  179. await runAll(
  180. ['--parallel', 'test-task:echo a', 'test-task:echo abcd', 'test-task:echo ab', '--print-label'],
  181. stdout
  182. )
  183. for (const line of EXPECTED_LINES) {
  184. assert(stdout.value.indexOf(line) !== -1)
  185. }
  186. for (const pattern of UNEXPECTED_PATTERNS) {
  187. assert(!pattern.test(stdout.value))
  188. }
  189. })
  190. it('run-p command', async () => {
  191. const stdout = new BufferStream()
  192. await runPar(
  193. ['test-task:echo a', 'test-task:echo abcd', 'test-task:echo ab', '--print-label'],
  194. stdout
  195. )
  196. for (const line of EXPECTED_LINES) {
  197. assert(stdout.value.indexOf(line) !== -1)
  198. }
  199. for (const pattern of UNEXPECTED_PATTERNS) {
  200. assert(!pattern.test(stdout.value))
  201. }
  202. })
  203. })
  204. })