/exp-addons

Shared model and frame definitions for the Lookit/ Experimenter behavioral data collection service

Primary LanguageJavaScriptApache License 2.0Apache-2.0

Experimenter Addons

A shared home for all of our shared addons

For historical reasons, all PRs targeted to ISP must be aimed at the "ISP" branch.

Installation

Before beginning, you will need to install Yarn, a package manager (like npm).

Install the submodule:

This repo module should included as a submodule in the Ember project where you want to use these addons. An example setup might be:

/<ember-project>
  /ext
    /exp-addons
  /app
    ...    

And the corresponding package.json entries are:

{
  ...,
  "dependencies": {
    "exp-player": "file:./ext/exp-addons/exp-player",
    "exp-models": "file:./ext/exp-addons/exp-models"
  }
}

For example:

cd lib && \
git submodule init && \
git submodule update && \
cd exp-models && \
yarn install --pure-lockfile

Development

If your work requires that you make changes to one of the exp-addon modules you can use yarn link for local development. This allows you to make changes to the code without having to push to github. To do this:

ROOT=`git rev-parse --show-toplevel`
cd $ROOT/ext/exp-addons/exp-player && \
yarn link && \
cd $ROOT/ext/exp-addons/exp-models && \
yarn link && \
cd $ROOT && \
yarn link exp-player && \
yarn link exp-models

Adding dependencies on other packages

Sometimes, you will want to install an additional third-party package. In place of npm, this project uses yarn. Most of the commands are the same, but this alternative tool provides a way for two developers to guarantee they are using the same versions of underlying code. (by running yarn install --pure-lockfile) This can help avoid a situation where things break unexpectedly when run on a different computer.

Whenever you choose to update your dependencies (yarn add x or yarn install), make sure that code still runs, then be sure to commit the modified yarn.lock file, which represents the "current known working state" for your app.

Any changes made in exp-player (except adding files, in which case you may need to relink the module) should now be automagically reflected in the consuming project.

Updating docs

Documentation of exp-player components is generated using YUIDoc:

$ cd exp-player
$ yarn run docs

At the moment, this is a manual process: whatever files are in the top level /docs/ folder of the master branch will be served via GitHub pages. New documentation releases will require manually making a new "release" to update the master branch, which can be done on request.

Releasing a new version

Within the exp-player folder, we provide a simple convenience command for handling new version releases: yarn run bump-version <MAJOR | MINOR| PATCH>.

This command handles incrementing the version number, verifying tests pass, and updating the documentation build. You will be responsible for committing the changes before handling the actual release (using a process such as git flow).

COS is Hiring!

Want to help save science? Want to get paid to develop free, open source software? Check out our openings!