-
Install the dependencies
npm install
-
Start the server
npm start
-
Navigate to :
http://localhost:8080/
- Setup Git if it isn't already (link).
- New to git or need a refresher? Now's a good time to learn! Easy tutorials here.
- Make sure your SSH keys are configured (linux | mac | windows).
- Double-check your settings for name and email:
git config --get-regexp user.*
. - Recommended Git settings:
git config --global fetch.prune true
- when fetching remote changes, remove any remote branches that no longer exist on the remote.
- Have commit access to CesiumJS?
- No
- Fork cesium.
- Use the GitHub website to delete all branches in your fork except
main
. - Clone your fork, e.g.,
git clone [email protected]:yourusername/cesium.git
. - Make changes in a branch, e.g.,
git checkout -b my-feature
.
- Yes
- Clone the cesium repo, e.g.,
git clone [email protected]:CesiumGS/cesium.git
- Make changes in a branch, e.g.,
git checkout -b my-feature
.
- Clone the cesium repo, e.g.,
- No
Prerequisites:
- Install Node.js on your system. Building Cesium requires Node 16.x or newer.
Cesium uses npm modules for development, so after syncing, you need to run npm install
from the Cesium root directory:
npm install
Cesium ships with a simple HTTP server for testing.
Once all modules have been installed, run npm start
to use it:
npm start
Then browse to http://localhost:8080/. The landing page includes apps and tools commonly used during development, including:
- Hello World : an example for how to create a 3D globe. Tutorial here
- Sandcastle : an app for viewing and creating code examples, complete with a live preview
- Test Suites : tests using Jasmine. Testing guide here.
- Documentation : reference documentation built from source. Documentation guide here.
By default, the server only allows connections from your local machine. To allow connections from other machines, pass
the --public
option to npm. Note the extra --
is intentional and required by npm.
npm start -- --public
The development server has a few other options as well, which you can see by passing the --help
parameter:
npm start -- --help
Cesium offers a few different distributions. When developing, make sure to pick the one that fits your app's architecture.
- IIFE (immediately-invoked function expression) - A pre-processed bundle and optimized for the browser, which defines a
Cesium
global variable upon loadingBuild/Cesium/Cesium.js
. While much of our documentation uses IIFE-style globals for ease-of-use, we do not recommend this approach for production apps. - ESM (ECMAScript modules) - Standard for packaging JS code which is supported by most browsers and NodeJS. Modules use
import
andexport
statements. Unprocessed, individual modules are available in theSource
directory, accessible by importingSource/Cesium.js
; A single pre-processed bundle by importingBuild/Cesium/index.js
. - CJS (CommonJS) - A pre-processed, bundled module packaged for running in NodeJS accessible by requiring
index.cjs
.
In much of our documentation, we use IIFE as it can be easily loaded with a CDN and defines a global Cesium variable with all modules attached.
For a production app, we recommend using the Source
modules directly which will allow your build tool of choice to reduce the final release's size using tree shaking.
Read the complete list of build scripts and options below for more details.
While you can use the editor of your choice to develop Cesium, certain files, such as glsl
and new tests, require that
the build
task be executed in order for the changes to take effect. You can use the build-watch
script to have this
happen automatically.
Cesium uses gulp for build tasks, but they are all abstracted away by npm run scripts.
Specify the target(s) at the command line:
npm run [target-name]
Here's the full set of scripts and what they do.
- Build scripts -- build and package the source code and documentation
build
- A fast, developer-oriented build that bundles the source modules to produce all-in-one files in theBuild/CesiumUnminified
directory that exposes the entire Cesium API attached to a single globalCesium
object. Run this when a GLSL shader is changed since the .glsl file is converted to a .js file with a string for the GLSL source.--minify
- Minifies the output for optimized loading. Specifying this option will output toBuild/Cesium
.--removePragmas
- Optimizes the output by removing debugging code that validates function input and throwsDeveloperError
s. The removed sections are marked with//>>includeStart('debug', pragmas.debug);
blocks in the code.--node
- Bundles anindex.cjs
module targeted for use in NodeJS
build-watch
- A never-ending task that watches your file system for changes to Cesium and builds the source code as needed. Allbuild
options are also available for this task.build-apps
- Builds the example applications (such as Cesium Viewer) to produce self-contained, minified, deployable versions in theBuild
directory.build-docs
- Generates HTML documentation inBuild/Documentation
using JSDoc 3. See the Documentation Guide for more details.build-ts
- Generates a TypeScript definitions file for the Cesium librarybuild-third-party
- GeneratesThirdParty.json
, a file which lists the latest licensing information of installed third party modulesrelease
- A full release build that creates a shippable product, including generating documentation.make-zip
- Builds a zip file containing all release files. This includes the source ESM modules, bundled ESM and IIFE formatCesium.js
, plus the bundled minified versions of ESM and IIFE, the generated documentation, the test suite, and the example applications (in both built and source form).
- Utility scripts -- code coverage, static code analysis, and other utilities
clean
- Removes all generated build artifactscloc
- Runs CLOC to count the lines of code on the Source and Specs directories. This requires Perl to execute.coverage
- Runs coverage and opens the default browser with the resultseslint
- Runs ESLint, a static code analysis tool, on the entire source treeprettier
- Formats the code base using Prettierprettier-check
- Verifies prettier formatting, but does not write the output
- Testing scripts -- build and run the unit tests
test
- Runs all tests with Karma using the default browser specified in the Karma config file.test-all
- Runs all tests with Karma using all browsers installed on the current systemtest-non-webgl
- Runs only non-WebGL teststest-webgl
- Runs only WebGL teststest-webgl-stub
- Runs all tests using the WebGL stub, which WebGL calls a noop and ignores related test expectationstest-webgl-validation
- Runs all tests with Karma and enables low-level WebGL validationtest-release
- Runs all tests on the minified release version of built Cesium
- Deployment scripts
deploy-s3
- Deploys the built CesiumJS files, the npm package, and the zip file to Amazon S3. This requires having credentials set up for the S3 bucket to which you are deployingdeploy-status
- Sets the deployment statuses in GitHub, for use with Travisdeploy-set-version
- Sets the version ofpackage.json
, for use with Travis
Cesium uses Travis for continuous integration. The Travis configuration and all the steps of the build process are defined in travis.yml
. The blog post Cesium Continuous Integration contains an in-depth explanation of the travis build process.
Travis triggers a build whenever someone opens a pull request or pushes code to the Cesium repository. After the build has completed, at the bottom on the pull request, the status of the build is shown and you can access the build by clicking the "Details" link.
You can also access the build of any branch of CesiumJS by going to the Cesium Branches page, and clicking the icon next to the branch name.
Additional set up is required for deployment if you do not have commit access to Cesium.
It is possible to configure your travis.yml
and gulpfile.js
to deploy to a different S3 Bucket (an Amazon Webservices storage unit). If you are using the cesium-dev bucket and have valid credentials, skip to Configure S3 Credentials
- In
travis.yml
, edit the following line:
- npm run deploy-s3 -- -b cesium-dev -d cesium/$TRAVIS_BRANCH --confirm -c 'no-cache'
- Edit
cesium-dev
to be the name of the S3 bucket you would like to deploy to - In
gulpfile.js
, edit the following line:
const travisDeployUrl =
"http://cesium-dev.s3-website-us-east-1.amazonaws.com/cesium/";
- Edit the URL to match the URL of the S3 bucket specified in
travis.yml
To configure Travis for deployment for a fork of Cesium, you must have valid credentials to the S3 bucket.
- Go to travis-ci.com and select your fork of Cesium
- Go to "More Options">"Settings"
- Under the "Environment Variables" section, add two environment variables,
AWS_ACCESS_KEY_ID
andAWS_SECRET_ACCESS_KEY
, with your access key and secret key
To configure the additional commit statuses on GitHub for your fork of Cesium, you need to generate a personal access token for Travis to use.
- In GitHub, go to "Settings" and "Personal access tokens"
- Click "Generate new token" and confirm your password when prompted
- Give a brief description of the token such as "Travis Statuses" and select "repo:status" and click "Generate token"
repo:status
gives the token access to only commit statuses
- Copy the token to your clipboard
- Go to travis-ci.com and select your fork of Cesium
- Go to "More Options">"Settings"
- Under the "Environment Variables" section, add the environment variable
TOKEN
and paste your token for the value