I am writing an end-to-end test using Protractor for my Angular application. I can mock httpBackend for unit test but I want to actually call the server and get the JSON response back and write tests again the data returned.
I have read a lot on stackoverflow but can not understand how this is done.
Do I use $http? How do I inject it into my Jasmine tests? How do I get the response JSON back into my Jasmine test?
any help or links to resources with instructions on doing this will be helpful.
Again I do NOT want to mock to server, I want to hit the server and get the JSON back.
Thanks!
I'm working through this myself at the moment. The short answer I think is that you set up your application exactly the same as if you were manually testing it yourself - so Protractor is really just a robot user, it has no (well, almost no) access to the internals of your application.
So, if your application needs a web server (and most do), then you start up that web server, then have protractor connect to your application via the browser and exercise it.
For my case, I'm aiming to use grunt to call a task that does basic database setup before it starts running my protractor e2e tests - this should give me a known database state.
For an example of this, I've been writing a tutorial for using Rails 4 with AngularJS, the section on using protractor for e2e testing is not rails-specific and might be useful: http://technpol.wordpress.com/2013/11/16/5-end-to-end-testing/
Protractor should be used for end-to-end testing of your full stack.
In this scenario the test typically exercises the angular application (filling form, pressing buttons) which will trigger the angular application to call to the REST server, which returns data, which your Angular application transforms in DOM changes, which then your end-to-end test asserts on.
This means that you probably want to start your application server (which hosts the angular application and is the REST backend, I suppose) before starting Protractor
How to do that is out of scope for Protractor.
The difficulty in this is typically how to setup your database, so that the e2e test knows what to expect as returns to your JSON services.
Below is an example of how to automatically start and stop a separate node server only while the e2e tests run. A simple express mock server script is included as an example API.
protractor.conf.js
mock-server/index.js
For continuous integration environments, you can install the mock server node_modules without changing directories like this:
We do this type of "hit the API directly and test the data in the response" integration testing in addition to our Protractor e2e testing. For the API-side testing, you don't need Protractor, because there's no need to fire up a browser just to send HTTP requests to a server.
Here's what we do:
describe()/it()/expect()
grammar from our Protractor environment (which is based on Jasmine). So rather than running protractor to run tests, you run jasmine, a la:jasmine --config=jasmine.json path/to/tests/*spec.js
Our spec files look something like this:
Our spec files depend on some global helper methods that we set up in a Jasmine helper file (part of the standard mechanics of how Jasmine works), like below:
I hope this helps.