Understanding, Installing, running and developing the browser tier of marklogic-samplestack
The Samplestack web application is built with AngularJS. It is built to run from a static web server and to access the Samplestack middle-tier via AJAX.
In development, the two servers are proxied together on port 3000 in order to make some of the browser development activities work, and to simplify the networking when running locally.
To use the webapp in a browser, you should be running the middle-tier tier app (and the MarkLogic server).
Conversely, to unit test the webapp, you need not be running the middle tier -- the middle tier will neither help nor hurt the the webapp unit tests as they are independent of the middle tier.
To configure and develop the browser app for Samplestack, you need the following software:
- Node.js, version 0.10 or later. See nodejs.org.
- A global installation of the Node.js components bower and gulp. (MarkLogic has tested with bower version 1.3.12.)
Before you begin, please ensure that node.js and git are installed. It is a good idea to update node.js if you have not installed a recent version, but it is believed that any 0.10 or 0.11 version will work.
Important: you should run all of the commands discussed in this page in a different terminal window from the Java middle-tier. This allows you to have the middle-tier running simultaneously with the the browser tier.
In general, Windows, OSX and Linux should work.
What will NOT work is Cygwin. In order to run the development version of the browser app on a Windows machine, you should have installed both node.js and git into your Windows environment and you should not use the Cygwin command shell to run any of the commands below. Node, and particularlly npm, do not expect the enviornment that Cygwin presents. The commands will fail if you run them from Cygwin or if you try to use versions of node, npm or git that were installed into your Cygwin sub-environment.
The following instructions should allow you:
- install prerequisites;
- install the webapp itself;
- build it and run its unit tests;
- visit the application in the browser;
- (re)run the unit tests in the browser;
- review the code-coverage report for the unit tests;
- execute and report on end-to-end tests of the 3-tiered application
There are two node.js components that you must have installed globally on your machine: bower and gulp
Use npm, which should be installed with node.js, to install them:
(from-anywhere)> npm install -g bower
(from-anywhere)> npm install -g gulp
If you see errors running either of the install commands above, you may need escalated privileges. Many installations of node are configured such that installation of global components requires admin privileges. If you receive permissions-based errors running these commands, please use elevated privileges to run them.
In *nix-based operating systems (including Mac OSX), this can be accomplished by prefixing the commands with sudo
.
In Windows, one way to do this is to launch a Command Prompt
with elevated privileges by right-clicking it from the Start Menu as selecting "Run as Administrator"
and then executing the commands.
The first time you want to run the webapp, please follow these directions. Also repea them any time you pull down an updated version of Samplestack from Github, as the dependencies which these steps install may have changed.
We are installing various node.js utilities that are used in the build, and we are installing various browser libraries that are used by the webapp itself. These command should not require elevated privileges. Unless you really know why you're doing so, do not use sudo
or an elevated shell to execute them.
From the marklogic-samplestack directory:
marklogic-samplestack> cd browser
marklogic-samplestack/browser> npm install
marklogic-samplestack/browser> bower install
If you get this far without errors, your Samplestack browser installation is complete.
If npm install gives you errors, see npm install errors below.
On Mac OSX, if you get errors coming from the ~/.npm directory, please do the following:
sudo chown -R $(whoami) ~/.npm
npm cache clean
mkdir ~/.npm
to seize ownership of that directory and clean the cache,
and then re-run npm install
.
A single command will build the webapp, execute its tests, generate online documentation and run a few web servers that enable you to run the application itself as well as examine some of the internals.
marklogic-samplestack/browser> gulp run
From here, you are presented with a menu that points to three web servers, in order they are:
- BUILD server: http://localhost:3000: This is the built application. Unlike the other services presented in the list, this one, the app itself, depends on the middle-tier application to be fully functional. Use the login credentials
[email protected]
, passwordjoesPassword
to view and search content restricted to the Contributor role. - UNIT TESTS: http://localhost:3001/unit-runner.html: While the unit tests are executed during the build, they are not individually reported. This link allows you to re-run them in a web browser at any time, to see the individual test results, and even to expand each line item to see the code that comprsises each test.
- COVERAGE: http://localhost:3002/coverage: This is a report of the code coverage of unit tests. You can drill down into each part of the webapp by clicking on the rows of the report. As you drill down into individual files, you will see line-by-line color coding that represents how/if a given line or branch of the code has been executed by the unit tests. This is also a very handy way to browse the code itself.
The following command do everything that the run
command does, but additionally enters "watch mode". In watch mode, changes you make to the application, its tests, or its documentation are instantly incorporate into the build, unit tests are rerun and documentation regenerated.
From the marklogic-samplestack/browser sub-directory:
marklogic-samplestack/browser> gulp watch
In many cases, watch mode also causes a browser tab/window that is on app, the coverage report or the online documentation to be updated automatically via "Live Reload". Not all browsers will support this.
MacOS users, please see the note below about your watched files limit. If you don't follow the instructions it presents, you may get errors when you enter watch mode.
End-to-end testing involves building the entire application (database, middle-tier and browser application), putting it in run-mode, and executing tests specifically designed to evaluate the functionality as a whole.
There are many moving parts to end-to-end testing of a three-tiered application. If any one of them, including the test environment(s) themselves isn't working perfectly, it will be apparent from the end-to-end testing (subject, of course, to specific tests being written to test features).
Such tests are set up by automating the process of getting things running, then (again, automatically) launching a browser (or browsers) and "pretending" to be a human being using the application.
Selenium a server that is used to drive browsers, and web driver is a protocol that is used by Selenium to do that. End-to-end tests make requests to selenium in order to execute specific operations in the browser and to find out what is displayed at any given time.
"OpenSauce" is a service that is made available for free by SauceLabs for open source software testing using their farm of machines with browsers and selenium instances, accessible in the cloud.
Samplestack is configured to either run Selenium locally or to access SauceLabs.
gulp e2e
is the command that is used to execute end-to-end tests. There are several flags which control how the tests are executed.
--browser=[ie | ff | chrome | phantomjs]
: e.g.browser=ie
. Used to specify a browser to launch locally along with an automatically launched local Selenium server. You must have Java installed to run Selenium. The default value ischrome
.--sauce[={platorm-key} | =all | =supported(s)]
: specifies a specifc platform or set of platforms on which to execute tests remotely using SauceLabs. To run these tests, you must supply credentials. Seebrowser/credentials.js
for information on configuring Sauce credentials. The list of browser/operating system combinations that will be run if you specify "all" or "supported" is listed inbrowser/options.js
. Any of the browsers configured to be runnable in that file may also be specified individually by key, e.g.--sauce=win7-ie-10
. If both the--browser
and--sauce
flags are set, the task will fail. If--sauce
is specified with no platform, then it is equivalent to--sauce=supported
.--middle-tier=[java | external]
. Ifjava
is specified, then the middle tier automation code will be controlled by the task, such that a clean install of the Java middle-tier and database configuration will be performed and the middle tier will be started. On the contrary, ifexternal
is specified, then the task will assume that a middle tier server and database have already been configured and launched and are listening on port 8090. The default isexternal
.--broken="<comma-separated-tags>"
. Each tags is of the form@tagname
. These are tags present in the feature files. If specified, only features/scenarios which match this specification will be executed. To specify NOT to match a tag, prefix with~
. See example below regarding skipping tests that are known to be broken.
A few of examples:
gulp e2e # or gulp e2e --middle-tier=external --browser=chrome
Runs the tests against locally installed Chrome with automatically configured local Selenium server, assuming the middle-tier has been launched in a separate process, and prints the results to the console.
Please note: if you either do not specify the middle-tier flag pr specify external
, you are responsible for having a Java middle-tier running and ready. You are also responsible for ensuring that
your MarkLogic server has a clean/up-to-date Samplestack configuration and seed data. In other words, you should probably run the middle-tier teardown process if you're not sure of the state of your dataset/configuration.
gulp e2e --middle-tier=java --sauce --tags="~@broken"
This is almost the command that used by MarkLogic's nigthly regression system. It configures the MarkLogic server, launches the middle tier and executes the test suite against the list of supported browsers. It does not yet write to files and thus is not consumable by the test harness.
Note on ~@broken
: always specify this flag unless you are interested in seeing tests run which
are known to be broken. Such tests are also flagged in the feature files with issue id numbers, so
that they may be executed individually based on the issue that covers the problem.
Note: to use SauceLabs tests, please add a hosts file entry (or other domain resolution) that points "samplestack.local" to 127.0.0.1 on your machine. The reasons for this are documented in https://support.saucelabs.com/entries/27401240-Testing-with-a-localhost-server-and-some-browsers-can-t-load-my-website .
Please see Node.js and npm Tips for Samplestack Development.
In general your "watch" process is faster if you raise the limit of the number
of open files for your process or the system. However, in normal cases, there
is no harm (other than speed) to not raising the limit, because
gaze implements a different strategy when
it reaches that limit. However, at the present time two forces are combining
to make the watch
task problematic:
- OSX defaults to a very low limit
- gaze has a bug that is causing it to fail when that limit is reached.
Thus, while generally it's just a good idea to raise the limit, for now it's also mandatory on OSX.
To achive this, make or modify the file at ~/.launchd.conf
to have a line
reading:
limit maxfiles 16384 unlimited
and then log out of your OSX session and log back in (or just restart your machine).
Copyright © 2012-2015 MarkLogic
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.