runner.mjs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. import * as process from 'node:process'
  2. import waitOn from 'wait-on'
  3. import { spawn } from 'node:child_process'
  4. export default function getRunner () {
  5. const type = process.env.OLIVETIN_TEST_RUNNER
  6. console.log('OLIVETIN_TEST_RUNNER env value is: ', type)
  7. switch (type) {
  8. case 'local':
  9. return new OliveTinTestRunnerStartLocalProcess()
  10. case 'vm':
  11. return new OliveTinTestRunnerVm()
  12. case 'container':
  13. return new OliveTinTestRunnerEnv()
  14. default:
  15. return new OliveTinTestRunnerStartLocalProcess()
  16. }
  17. }
  18. class OliveTinTestRunner {
  19. BASE_URL = 'http://nohost:1337/';
  20. baseUrl() {
  21. return this.BASE_URL
  22. }
  23. metricsUrl() {
  24. return new URL('metrics', this.baseUrl());
  25. }
  26. }
  27. class OliveTinTestRunnerStartLocalProcess extends OliveTinTestRunner {
  28. async start (cfg) {
  29. let stdout = ""
  30. let stderr = ""
  31. console.log(" OliveTin starting local process...")
  32. this.ot = spawn('./../service/OliveTin', ['-configdir', 'configs/' + cfg + '/'])
  33. let logStdout = false
  34. if (process.env.CI === 'true') {
  35. logStdout = true;
  36. } else {
  37. logStdout = process.env.OLIVETIN_TEST_RUNNER_LOG_STDOUT === '1'
  38. }
  39. this.ot.stdout.on('data', (data) => {
  40. stdout += data
  41. if (logStdout) {
  42. console.log(`stdout: ${data}`)
  43. }
  44. })
  45. this.ot.stderr.on('data', (data) => {
  46. stderr += data
  47. if (logStdout) {
  48. console.log(`stderr: ${data}`)
  49. }
  50. })
  51. this.ot.on('close', (code) => {
  52. if (code != null) {
  53. console.log(`OliveTin local process exited with code ${code}`)
  54. console.log(stdout)
  55. console.log(stderr)
  56. console.log(this.ot.exitCode)
  57. }
  58. })
  59. if (this.ot.exitCode == null) {
  60. this.BASE_URL = 'http://localhost:1337/'
  61. console.log(" OliveTin waiting for local process to start...")
  62. await waitOn({
  63. resources: [this.BASE_URL]
  64. })
  65. console.log(" OliveTin local process started and webUI accessible")
  66. } else {
  67. console.log(" OliveTin local process start FAILED!")
  68. console.log(stdout)
  69. console.log(stderr)
  70. console.log(this.ot.exitCode)
  71. }
  72. }
  73. async stop () {
  74. if ((await this.ot.exitCode) != null) {
  75. console.log(" OliveTin local process tried stop(), but it already exited with code", this.ot.exitCode)
  76. } else {
  77. await this.ot.kill()
  78. console.log(" OliveTin local process killed")
  79. }
  80. if (process.env.CI === 'true') {
  81. // GitHub runners seem to need a bit more time to clean up
  82. await new Promise((res) => setTimeout(res, 3000))
  83. } else {
  84. await new Promise((res) => setTimeout(res, 100))
  85. }
  86. }
  87. }
  88. class OliveTinTestRunnerEnv extends OliveTinTestRunner {
  89. constructor () {
  90. super()
  91. const IP = process.env.IP
  92. const PORT = process.env.PORT
  93. this.BASE_URL = 'http://' + IP + ':' + PORT + '/'
  94. console.log('Runner ENV endpoint: ' + this.BASE_URL)
  95. }
  96. async start () {
  97. await waitOn({
  98. resources: [this.BASE_URL]
  99. })
  100. }
  101. async stop () {
  102. }
  103. }
  104. class OliveTinTestRunnerVm extends OliveTinTestRunnerEnv {
  105. constructor() {
  106. super()
  107. }
  108. async start (cfg) {
  109. console.log("vagrant changing config")
  110. spawn('vagrant', ['ssh', '-c', '"ln -sf /etc/OliveTin/ /opt/OliveTin-configs/' + cfg + '/config.yaml"'])
  111. spawn('vagrant', ['ssh', '-c', '"systemctl restart OliveTin"'])
  112. return null
  113. }
  114. }