##Travis docs - useful links
###Breakdown
-
Service Hook - Travis CI to GitHub
a. One-click after GitHub login. All branches at once.
b. Add .travis.yml file to project root directory.
-
Unit Tests - Mocha
a. Set up "npm test" command - this is what Travis runs
b. Call local installation of mocha, global throws permission errors
c. Travis posts success/failure/unknown image - can embed in this README (see above.)
-
Code Coverage - Istanbul
a. Install Istanbul, Istanbul hooks into Mocha, instruments code from tests, and produces code coverage results.
- Only instruments code referenced from unit tests.
b. Tell Travis to execute coverage tests, produces output as html.
c. TravisCI does not host files, so possible solution is to post back to a GitHub repository using encrypted OAuth token with Travis's public key.
d. Travis can post back to GitHub, see script example. Possibly can use Travis's environment variables to post back to correct branch, OR separate branch for coverage results, and have Travis create a directory for each branch.
- echo ${TRAVIS_BRANCH} = "master"
- echo ${TRAVIS_REPO_SLUG} = "https://github.com/tcbeutler/TravisCITest"
-
Viewing Code Coverage Results
a. GitHub cannot display pages hosted in a normal repository.
b. GitHub Pages hosts a public website from any branch added to a repo called "gh-pages".
GitHub pages are always public and served over http.
c. hasdocs provides privately hosted documentation with GitHub service hook for ~$5 a month.
d. Alternatively could host own service to pull and serve coverage results.