This document provides information for developers working on ngeo.
Type make help
to display available targets.
Let's say you're working on a new feature in a specific branch and want to
publish examples to show others what that new feature's UI looks like. The
Makefile provides a gh-pages
target for exactly this.
To publish the current branch's examples to GitHub Pages:
$ make gh-pages GITHUB_USERNAME=<your_github_username>
The GITHUB_USERNAME
variable is used to specify the user/organization name to
publish to on GitHub.
For example
$ make gh-pages GITHUB_USERNAME=camptocamp
will publish the examples to https://camptocamp.github.io/ngeo/<branchname>/
.
The published examples use the ngeo.js
standalone build.
Example: https://camptocamp.github.io/ngeo/master/examples/simple.html.
The unit tests are located in test/spec/
and uses the Jasmine Framework.
Please refer to the AngularJS's unit-testing guide for
how to write unit tests.
To run the unit tests on the command line, just run make test
. All the tests will be
run inside PhantomJS.
For debugging purposes it is useful to run the unit tests in an actual browser with
make test-debug
. This task starts the Karma server and opens Chrome/Chromium. Click on
Debug
to open a new page that runs all unit tests. Now you can start the debugger.
To run only a single test or test group, use fdescribe
or fit
to focus
on a test:
fdescribe('...', function() {
fit('...', function() {
Checkout the latest version
git checkout <release-branch>
git fetch origin
git reset --hard origin/<release-branche>
Where <release-branch>
stand for 2.x
.
Verify that the <version>
(2.x.x
) in package.json match with the tag you'll
create. Then create a tag named the same as the version.
git tag <version>
git push origin <version>
Travis will create a new package on npm.
If you create a new release, bump version in the package.json file:
git checkout -b bump
vi package.json
git add package.json
git commit -m "Bump version to <version + 1>"
git push origin bump
Do the pull request on branch <release-branche>
When we create a new stabilisation branch we should also duplicate the localisation.
Go on master:
git checkout master
git pull origin master
Create the new branch:
git checkout -b x.y
Update the .travis.yml
:
- provider: script
script: make transifex-send
skip_cleanup: true
on:
repo: camptocamp/ngeo
- branch: master
+ branch: x.y
Commit and push the changes:
git add .travis.yml
git commit -m "Update the branch"
git push origin x.y
Back on master:
git checkout master
Do the merge to prepare the future merges:
git merge x.y
Restore the .travis.yml
:
- provider: script
script: make transifex-send
skip_cleanup: true
on:
repo: camptocamp/ngeo
- branch: x.y
+ branch: master
Get the actual localisation:
make transifex-get
Update the Makefile
:
- TX_VERSION ?= x_y
+ TX_VERSION ?= x_y+1
Commit and push the changes:
git add Makefile .travis.yml
git commit -m "Start the version x.y+1"
git push origin master
Create the new localisation resource:
rm .tx/config contribs/gmf/apps/.tx/config
make transifex-init
Update the references in the index.html
file of the gh-pages
branch.