An implementation of the Schul-Cloud client with NodeJS and Express.
- node.js 8.7 or later
You might take a look at the Dockerfile to see some more dependencies and latest version informations.
German docs on installing: Setup SC
Short version:
- Clone directory into local folder
- Go into the cloned folder and enter
npm install
- Install nodemon and gulp globally by entering
npm install -g nodemon gulp
- Start the schul-cloud server
- Go into project folder
- run
gulp watch
to run gulp - Set the ENV-variable
TZ=Europe/Berlin
(for windows useset TZ=Europe/Berlin
). You can also set the variablesSC_TITLE=HPI Schul-Cloud
andSC_SHORT_TITLE=Schul-Cloud
if you want. - run
npm run watch
to boot the application - go to
http://localhost:3100
Alternative with browser-sync
- run
gulp watch reload
to run gulp with browser sync. It also starts the node-client-server. - go to
http://localhost:7000
For connecting to the SchulCloud Calendar-Service you have to set export CALENDAR_SERVICE_ENABLED=true
.
For connecting to the SchulCloud Notification-Service you have to set export NOTIFICATION_SERVICE_ENABLED=true
.
For activating Google Analytics tracking you have to set export GOOGLE_ANALYTICS_TRACKING_ID={TRACKING_ID}
.
Add Themes to /theme directory. Call gulp and node with SC_THEME set to name of directory.
then clear build files and gulp cache with gulp clear
run set SC_THEME={themeName}
without spaces around the equal sign!
- Take the Ticket Number from JIRA (ticketsystem.schul-cloud.org), e.g. SC-999
- Name the feature branch beginning with Ticket Number, all words separated by dash "-", e.g.
feature/SC-999-fantasy-problem
- Create a PR on branch develop containing the Ticket Number in PR title
- Keep the
WIP
label as long as this PR is in development, complete PR checklist (is automatically added), keep or increase code test coverage, and pass all tests before you remove theWIP
label. Reviewers will be added automatically. For more information check our Definition of Done here.
Information: Please make sure that all your changes works on Chrome , Firefox and Safari!
For html/css components please check caniuse.
- Set the password for the demo user
[email protected]
Ubuntu/Mac:export SC_DEMO_USER_PASSWORD={PASSWORD}
(Without braces)
Windows:set SC_DEMO_USER_PASSWORD={PASSWORD}
(Without braces) - run
npm run test
- If you want to use another backend url than localhost, set the
BACKEND_URL
andPUBLIC_BACKEND_URL
environment variables (see 1) - If you want to list the coverage, run
npm run coverage
Frontend Testing We are currently using nightwatch.js for frontend testing. The current api documentation can be found here.
- Start a client server with
npm run watch
- Open another command line and type
npm run frontendTests
to run tests against chrome and firefox.
In case you want browser specific tests use: ./node_modules/.bin/nightwatch --config nightwatch.conf.js --env chrome
or switch chrome with firefox.
Adding new tests:
- Copy any of the existing tests
- First test cases should be essentially the same, login, checkups, ...
- Add your test cases in between the checkups and the
browser.end()
Add your test to diff.sh
:
diff.sh
compares the PR Branch with the Master Branch and then adds the tests in case any files where changed for which a test exists.
Default branch: develop
- Go into project folder
- Checkout to develop branch (or clone for the first time)
- Run
git pull
- Create a branch for your new feature named feature/SC-Ticket-ID-Description
- Run the tests (see above)
- Commit with a meanigful commit message(!) even at 4 a.m. and not stuff like "dfsdfsf"
- Start a pull request (see above) to branch develop to merge your changes