angular-cli: Setting baseUrl in protractor.conf is not working
Versions
Angular CLI: 6.0.7
Node: 10.2.1
OS: darwin x64
Angular: 6.0.3
... animations, common, compiler, compiler-cli, core, forms
... http, language-service, platform-browser
... platform-browser-dynamic, router
Package Version
-----------------------------------------------------------
@angular-devkit/architect 0.6.7
@angular-devkit/build-angular 0.6.7
@angular-devkit/build-optimizer 0.6.7
@angular-devkit/core 0.6.7
@angular-devkit/schematics 0.6.7
@angular/cli 6.0.7
@ngtools/webpack 6.0.7
@schematics/angular 0.6.7
@schematics/update 0.6.7
rxjs 6.2.0
typescript 2.7.2
webpack 4.8.3
node: v10.2.1
npm: 6.1.0
macOS High Sierra 10.13.4
Repro steps
- In a new Angular Cli project, in the e2e folder open protractor.conf.js
- change baseUrl to https://google.com
- run ng e2e
Observed behavior
The brower opens up to http://localhost:4200/ and not https://google.com
Desired behavior
I think it should go to what the baseurl is set to.
Mention any other details that might be useful (optional)
I add browser.sleep(900000) in the first test after navigateTo so I have time to see what is going on.
About this issue
- Original URL
- State: closed
- Created 6 years ago
- Reactions: 2
- Comments: 15 (5 by maintainers)
You can pass –public-host arg to your ng e2e call (i.e: ng e2e --public-host=“https://hostname.com”)
It seems to have to do with using the “serve” target for that configuration, which for some reason overwrites the baseUrl from the protractor.conf. We managed to work around it by either modifying the default “production” e2e config to not use the “serve” as “devServerTarget”, or creating a separate configuration in the e2e project part of the angular.json for accessing a different webserver, like this:
The first “local” config is used for e2e testing against a locally running “ng served” web server, and the “remote” config is used to run the test suite against a remote web server, which is configured using the baseUrl in the different protractor.conf.remote.js.
Maybe this will help other people with the same problem.
Update: Just to clarify, you don’t need a separate protractor.conf in case you only want to overwrite the baseUrl. You can simply do that using the “baseUrl” property of the configuration, or the “base-url” command line parameter:
@intellix no, there isn’t a good way to call call
ng e2e
and send CLI overrides to the serve command, unfortunately.That’s an interest use case. I’m not sure how it can be addressed without fully exposing all transitive dependencies. Perhaps by allowing the config file to pull values from the environment or commands.
One problem I have is that the value needs to be dynamic as we don’t know where the server is going to be accessible from ahead of time.
We’re using Jenkins pipelines to run the e2e tests. That Jenkins executor is bought up dynamically within a Kubernetes cluster and will have a randomised IP. Our Selenium grid deploys pods in Kubernetes and needs to be able to access the
ng e2e
web-server running within randomly placed Jenkins executor pod.package.json scripts:
Jenkinsfile pipeline for starting the e2e tests:
docker-compose.yml:
Inside the protractor.config.js file:
When you deploy within a K8S cluster the host/port are totally randomised and I don’t see how this can be accomplished within
angular.json
without using bash magicEverything I used to use was ripped away from CLI and placed into static configuration files and it just gets more and more difficult to accomplish 😃
I’m setting up a Selenium grid and after getting it to work, wanted to share a composition of what you need to do.
Basically the workaround is to remove the
devServerTarget
frommyapp-e2e.targets.e2e.options
and manually serve, so something like this for an external e2e server that needs to talk to your app:angular.json snippet:
protractor.conf.js:
commands to run in parallel:
ng e2e will instruct the external Selenium server to run tests against the server accessible via baseUrl
@mtaylor769 Sorry I should have explained that the options block was omitted for brevity