konva/README.md

26 lines
2.5 KiB
Markdown
Raw Normal View History

2012-12-21 23:53:26 +08:00
#Building the KineticJS Framework
2013-01-02 10:07:43 +08:00
To build the framework, you need to have Ruby and Rubygems installed. After that, run `gem install thor`, `gem install json_pure`, and `gem install uglifier` to install the dependencies.
2013-01-02 10:07:43 +08:00
To build a development version of the framework, run `thor build:dev VERSION`, where VERSION is a string that can be anything you like. For example, using `thor build:dev current` will produce `kinetic-vcurrent.js`. To build a minified version of the framework, run `thor build:prod VERSION`.
If you add a file in the src directory, be sure to add the filename to the filename array in the Thorfile.
#Testing
2012-12-04 12:12:38 +08:00
### Getting the tests up and running
2012-12-04 12:11:31 +08:00
Currently, KineticJS has unit, functional, performance, manual, and special test suites. To build the unit tests, you'll need to build the `unitTests.js` file by running `thor build:test` and then opening `unitTests.html`. Open `tests/html/index.html` to navigate to different test suites.
2012-12-04 12:12:38 +08:00
### Running the tests
2012-12-04 12:11:31 +08:00
Unit, functional, and performance tests output the results to the console via `console.log()` so be sure to have it open.
In order for the data url tests and image manipulation tests to pass, you need to run the unit test suite on a web server due to canvas security constraints ([read more about that here](http://www.whatwg.org/specs/web-apps/current-work/multipage/the-canvas-element.html#security-with-canvas-elements)). All tests should pass in Google Chrome on Windows 7 with no warnings, and all tests should pass with some warnings in other browsers and operating systems.
2012-12-04 12:11:31 +08:00
2012-12-04 12:12:38 +08:00
### Updating the tests
2012-12-04 12:11:31 +08:00
To add / modify unit tests, be sure to do so in the `tests/js/unit` directory, because these are the source test files that are concatenated together when building `unitTests.js`. Use `test()` for hard tests which will throw an error if something fails, and use `warn()` for soft tests that will allow the tests to continue if the test condition fails. The `warn()` method is great for tests that will have different results in different browsers, such as canvas data url comparisons, text metric dimensions, etc.
TIP: prepend a test name with a `*` to only run that particular test, or prepend a test name with `!` to omit that test.
#Pull Requests
I'd be happy to review any pull requests that may better the KineticJS project, in particular if you have a bug fix, enhancement, or a new shape (see `src/shapes` for examples). Before doing so, please first make sure that all of the unit tests and functional tests pass.