Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Gitlab build fails with docker image cypress/included:3.8.3 #6279

Closed
bahrmichael opened this issue Jan 30, 2020 · 10 comments · Fixed by #6280
Closed

Gitlab build fails with docker image cypress/included:3.8.3 #6279

bahrmichael opened this issue Jan 30, 2020 · 10 comments · Fixed by #6280
Assignees
Labels
CI General issues involving running in a CI provider cli type: error message

Comments

@bahrmichael
Copy link

I'm trying to run a gitlab cicd job with cypress/included:3.8.3 as the base image.

e2e:
    image: cypress/included:3.8.3
    script:
        - cypress run --record --project ./e2e --config-file ./e2e/cypress-ci.json

Current behavior:

The build stalls with the following message. Tests don't seem to run at all.

Uncaught Exception:
 TypeError: Cannot read property 'split' of undefined
     at pipesToCommas (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/lib/util/args.js:77:14)
     at JSONOrCoerce (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/lib/util/args.js:97:9)
     at /root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/node_modules/lodash/lodash.js:13401:38
     at /root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/node_modules/lodash/lodash.js:4905:15
     at baseForOwn (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/node_modules/lodash/lodash.js:2990:24)
     at Function.mapValues (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/node_modules/lodash/lodash.js:13400:7)
     at /root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/node_modules/lodash/lodash.js:4368:28
     at arrayReduce (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/node_modules/lodash/lodash.js:683:21)
     at baseWrapperValue (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/node_modules/lodash/lodash.js:4367:14)
     at LodashWrapper.wrapperValue (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/node_modules/lodash/lodash.js:9050:14)
     at sanitizeAndConvertNestedArgs (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/lib/util/args.js:135:4)
     at Object.toObject (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/lib/util/args.js:243:24)
     at Object.start (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/lib/cypress.js:154:31)
     at Object.<anonymous> (/root/.cache/Cypress/3.8.3/Cypress/resources/app/packages/server/index.js:27:43)
     at Module._compile (internal/modules/cjs/loader.js:880:30)
     at Object.Module._extensions..js (internal/modules/cjs/loader.js:892:10)
     at Module.load (internal/modules/cjs/loader.js:735:32)
     at Module._load (internal/modules/cjs/loader.js:648:12)
     at Module._load (electron/js2c/asar.js:717:26)
     at Function.Module._load (electron/js2c/asar.js:717:26)
     at Module.require (internal/modules/cjs/loader.js:775:19)
     at require (internal/modules/cjs/helpers.js:68:18)
     at Object.<anonymous> (/root/.cache/Cypress/3.8.3/Cypress/resources/app/index.js:2:1)
     at Module._compile (internal/modules/cjs/loader.js:880:30)
     at Object.Module._extensions..js (internal/modules/cjs/loader.js:892:10)
     at Module.load (internal/modules/cjs/loader.js:735:32)
     at Module._load (internal/modules/cjs/loader.js:648:12)
     at Module._load (electron/js2c/asar.js:717:26)
     at Function.Module._load (electron/js2c/asar.js:717:26)
     at Object.<anonymous> (electron/js2c/browser_init.js:5718:12)
     at Object../lib/browser/init.ts (electron/js2c/browser_init.js:5725:30)
     at __webpack_require__ (electron/js2c/browser_init.js:20:30)
     at electron/js2c/browser_init.js:84:18
     at electron/js2c/browser_init.js:87:10
     at NativeModule.compile (internal/bootstrap/loaders.js:302:5)
     at NativeModule.compileForPublicLoader (internal/bootstrap/loaders.js:219:8)
     at loadNativeModule (internal/modules/cjs/helpers.js:23:9)
     at Module._load (internal/modules/cjs/loader.js:630:15)
     at Module._load (electron/js2c/asar.js:717:26)
     at Function.Module._load (electron/js2c/asar.js:717:26)
     at Function.Module.runMain (internal/modules/cjs/loader.js:944:10)
     at internal/main/run_main_module.js:17:11
 Fontconfig warning: "/etc/fonts/fonts.conf", line 100: unknown element "blank"

Desired behavior:

I would like the tests to start and complete.

Test code to reproduce

Code for reproduction: https://gitlab.com/mptickets/gitlab-reproducer
Build that shows the failure: https://gitlab.com/mptickets/gitlab-reproducer/-/jobs/421010601

Versions

Cypress docker image: cypress/included:3.8.3

@bahmutov bahmutov self-assigned this Jan 30, 2020
@bahmutov
Copy link
Contributor

I can recreate this problem in https://gitlab.com/cypress-io/cypress-example-included. When looking at debug logs with DEBUG=cypress:cli I see weird config parsed

2020-01-30T18:03:31.544Z cypress:cli NODE_OPTIONS is not set
 2020-01-30T18:03:31.586Z cypress:cli parsed cli options 
{ config: 'if [ -x /usr/local/bin/bash ]; then\n' + 
'\texec /usr/local/bin/bash \n' + 'elif [ -x /usr/bin/bash ]; then\n' + 
'\texec /usr/bin/bash \n' + 'elif [ -x /bin/bash ]; then\n' + 
'\texec /bin/bash \n' + 'elif [ -x /usr/local/bin/sh ]; then\n' + 
'\texec /usr/local/bin/sh \n' + 'elif [ -x /usr/bin/sh ]; then\n' + 
'\texec /usr/bin/sh \n' + 'elif [ -x /bin/sh ]; then\n' + 
'\texec /bin/sh \n' + 'elif [ -x /busybox/sh ]; then\n' + 
'\texec /busybox/sh \n' + 'else\n' + '\techo shell not found\n' + 
'\texit 1\n' + 'fi\n' + '\n' }

Hmm, how is this running there

@bahmutov
Copy link
Contributor

Second problem: after the crash, the process does NOT exit, so we are not handling the error correctly.

Screen Shot 2020-01-30 at 1 16 53 PM

@bahmutov
Copy link
Contributor

Running with DEBUG=cypress:cli:cli shows there are arguments coming from GitLab CI script?

Screen Shot 2020-01-30 at 1 19 09 PM

These are not part of our Docker image

$ docker run -it --entrypoint=/bin/bash cypress/included:3.8.3
root@b01a4742c330:/# DEBUG=* cypress run
  cypress:cli:cli cli starts with arguments ["/usr/local/bin/node","/usr/local/bin/cypress","run"] +0ms
  cypress:cli NODE_OPTIONS is not set

@bahmutov
Copy link
Contributor

For reference, here is Cypress CLI entry script

$ docker run -it --entrypoint=/bin/bash cypress/included:3.8.3
root@0ef9cbfda54b:/# which cypress
/usr/local/bin/cypress
root@0ef9cbfda54b:/# cat /usr/local/bin/cypress
#!/usr/bin/env node

require('../lib/cli').init()

@bahmutov
Copy link
Contributor

@bahrmichael I have solved the immediate issue, see https://gitlab.com/cypress-io/cypress-example-included Turns out GitLab wraps entrypoint in its own script, breaking it. So you need to clear the entrypoint like this

e2e:
  image:
    name: cypress/included:3.8.3
    # cypress/included images have entrypoint set to "cypress"
    # which conflicts with GitLab CI wrapper shell script
    entrypoint: [""]
  script:
    - cypress run --project ./e2e

I will keep this issue open for myself - we still need to catch the config parsing exception and exit with status code and not keep the test runner hanging.

@bahmutov bahmutov added the cli label Jan 30, 2020
@bahmutov
Copy link
Contributor

Trying this locally, the hanging might be GitLab thing, local npm run dev with invalid config does exit fine (but without explaining what is going on)

@bahmutov
Copy link
Contributor

Simplest case that crashes:

DEBUG=cypress:server:args npm run dev -- --project ~/git/cypress-test-tiny --config 'a'
  cypress:server:args parsing config: a +0ms

/Users/gleb/git/cypress/packages/server/lib/util/args.js:77
  return str.split('|').join(',')
             ^
TypeError: Cannot read property 'split' of undefined

@bahrmichael
Copy link
Author

@bahrmichael I have solved the immediate issue, see https://gitlab.com/cypress-io/cypress-example-included Turns out GitLab wraps entrypoint in its own script, breaking it. So you need to clear the entrypoint like this

e2e:
  image:
    name: cypress/included:3.8.3
    # cypress/included images have entrypoint set to "cypress"
    # which conflicts with GitLab CI wrapper shell script
    entrypoint: [""]
  script:
    - cypress run --project ./e2e

That fixed it for me. Thank you very much for the quick response!

@cypress-bot cypress-bot bot added stage: needs review The PR code is done & tested, needs review stage: work in progress and removed stage: work in progress stage: needs review The PR code is done & tested, needs review labels Jan 31, 2020
@cypress-bot
Copy link
Contributor

cypress-bot bot commented Feb 1, 2020

The code for this is done in cypress-io/cypress#6280, but has yet to be released.
We'll update this issue and reference the changelog when it's released.

@cypress-bot cypress-bot bot removed the stage: needs review The PR code is done & tested, needs review label Feb 1, 2020
@flotwig
Copy link
Contributor

flotwig commented Feb 6, 2020

Released in 4.0.0.

@cypress-io cypress-io locked as resolved and limited conversation to collaborators Mar 3, 2020
@jennifer-shehane jennifer-shehane added CI General issues involving running in a CI provider and removed CI: gitlab labels Oct 5, 2023
# for free to subscribe to this conversation on GitHub. Already have an account? #.
Labels
CI General issues involving running in a CI provider cli type: error message
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants