This document describes how to set up your workstation to develop for Code.org.
You can do Code.org development using OSX, Ubuntu, or Windows (running Ubuntu in a VM). Setup for Windows is more complicated and relatively few developers use it. Make sure you follow the instructions for your platform in the subsections below.
-
Install OS-specific prerequisites
-
If using SSH (recommended):
git clone [email protected]:code-dot-org/code-dot-org.git
, if using HTTPS:git clone https://github.com/code-dot-org/code-dot-org.git
, -
gem install bundler -v 1.17.3
-
rbenv rehash
-
cd code-dot-org
-
bundle install
- This step often fails to due environment-specific issues. Look in the Bundle Install Tips section below for steps to resolve many common issues.
-
bundle exec rake install:hooks
Troubleshoot: `rake aborted! Gem::LoadError: You have already activated...`
- If you have issue
"rake aborted! Gem::LoadError: You have already activated rake 12.3.0, but your Gemfile requires rake 11.3.0."
, make sure you addbundle exec
in front of therake install:hooks
command
Troubleshoot: wrong version of rake
- You might get a message at some point about having the wrong version of rake. If so, try:
$> gem uninstall rake $> bundle update rake
- If you have issue
-
bundle exec rake install
- This can take a long time, ~30 minutes or more. The most expensive are the "seeding" tasks, where your local DB is populated from data in the repository. Some of the seeding rake tasks can take several minutes. The longest one,
seed:scripts
, can take > 10 minutes, but it should at least print out progress as it goes.
- This can take a long time, ~30 minutes or more. The most expensive are the "seeding" tasks, where your local DB is populated from data in the repository. Some of the seeding rake tasks can take several minutes. The longest one,
-
fix your database charset and collation to match our servers
bin/dashboard-sql
ALTER DATABASE dashboard_development CHARACTER SET utf8 COLLATE utf8_unicode_ci;
ALTER DATABASE dashboard_test CHARACTER SET utf8 COLLATE utf8_unicode_ci;
-
bundle exec rake build
- This may fail if your are on a Mac and your OSX XCode Command Line Tools were not installed properly. See Bundle Install Tips for more information.
-
(Optional, Code.org engineers only) Setup AWS - Ask a Code.org engineer how to complete this step
- Some functionality will not work on your local site without this, for example, some project-backed level types such as https://studio.code.org/projects/gamelab. This setup is only available to Code.org engineers for now, but it is recommended for Code.org engineers.
-
Run the website
bin/dashboard-server
-
Visit http://localhost-studio.code.org:3000/ to verify it is running.
-
Install necessary plugins described in the Editor configuration section below.
After setup, read about our code styleguide, our test suites, or find more docs on the wiki.
-
Choose shell. Starting in Catalina, the default shell for new users is zsh. Most developers at Code.org are still using bash so that may be a smoother experience for now.
To use bash:
- Switch the default shell back to bash and disable the warning:
chsh -s /bin/bash
- Add the following to
~/.bash_profile
or your desired shell configuration file:export BASH_SILENCE_DEPRECATION_WARNING=1
Optional configuration steps for zsh:
- Setup git prompt and git autocompletion
- Download git-prompt.sh
mkdir -p ~/bin/oh-my-zsh curl https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/plugins/gitfast/git-prompt.sh > ~/bin/oh-my-zsh/git-prompt.sh
- Add the following to
~/.zshrc
or your desired shell configuration file:# git prompt source ~/bin/oh-my-zsh/git-prompt.sh GIT_PS1_SHOWCOLORHINTS=1 GIT_PS1_SHOWDIRTYSTATE=1 GIT_PS1_SHOWUNTRACKEDFILES=1 setopt PROMPT_SUBST ; PS1='%m:%~$(__git_ps1 " (%s)")\$ ' # git completion source /Library/Developer/CommandLineTools/usr/share/git-core/git-completion.zsh >/dev/null 2>&1 # make git checkout not show remote branches GIT_COMPLETION_CHECKOUT_NO_GUESS=1 autoload -Uz compinit && compinit
- fix any problems with compinit:
compaudit | xargs chmod g-w
- Download git-prompt.sh
- Switch the default shell back to bash and disable the warning:
-
Install Homebrew:
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
-
Install Redis:
brew install redis
-
Run
brew install https://raw.github.com/quantiverge/homebrew-binary/pdftk/pdftk.rb enscript gs [email protected] nvm imagemagick rbenv ruby-build coreutils sqlite parallel
Troubleshoot: pdftk errors
- If it complains about pdftk, removing https://raw.github.com/quantiverge/homebrew-binary/pdftk/pdftk.rb from the above command seems to not have serious side effects (it will cause
PDFMergerTest
to fail). It may be a new URL is needed in the dependency list, see https://leancrew.com/all-this/2017/01/pdftk/
Troubleshoot: old version of
<package>
- If it complains about an old version of
<package>
, runbrew unlink <package>
and runbrew install <package>
again
- If it complains about pdftk, removing https://raw.github.com/quantiverge/homebrew-binary/pdftk/pdftk.rb from the above command seems to not have serious side effects (it will cause
-
Set up MySQL
- Force link 5.7 version:
brew link [email protected] --force
- Have
launchd
start mysql at login:ln -sfv /usr/local/opt/mysql/*.plist ~/Library/LaunchAgents
- Note, if mysql folder name is "[email protected]", replace the command above by
ln -sfv /usr/local/opt/[email protected]/*.plist ~/Library/LaunchAgents
. (Usels -d /usr/local/opt/mysql*
to check for folder name.)
- Note, if mysql folder name is "[email protected]", replace the command above by
- Start mysql now:
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.mysql.plist
- Note: if this fails check your plist file (
ls ~/Library/LaunchAgents/
) to see if it is "[email protected]". If it is try:launchctl load ~/Library/LaunchAgents/[email protected]
instead
- Note: if this fails check your plist file (
- Force link 5.7 version:
-
Set up rbenv
- Run
rbenv init
- Add the following to
~/.bash_profile
or your desired shell:eval "$(rbenv init -)"
. More info here. - Pick up those changes:
source ~/.bash_profile
- Run
-
Install Ruby 2.5.0
rbenv install 2.5.0
- Set the global version of Ruby:
rbenv global 2.5.0
- Install shims for all Ruby executables:
rbenv rehash
. More info here.
-
Set up nvm
-
Create nvm's working directory if it doesnt exist:
mkdir ~/.nvm
-
Add the following to
~/.bash_profile
or your desired shell configuration file:# Load nvm function into the shell export NVM_DIR=~/.nvm source $(brew --prefix nvm)/nvm.sh
-
Pick up those changes:
source ~/.bash_profile
-
-
Install Node and yarn
nvm install 8.15.0 && nvm alias default 8.15.0
this command should make this version the default version and print something like:Creating default alias: default -> 8.15.0 (-> v8.15.0)
npm install -g [email protected]
.- (Note: You will have to come back to this step after you clone your repository) Reinstall node_modules
cd apps; yarn; cd ..
-
Install OpenSSL:
brew install openssl
export LIBRARY_PATH=$LIBRARY_PATH:/usr/local/opt/openssl/lib/
-
If you want to render personalized certificates locally, see these special instructions regarding ImageMagick with pango.
-
Prevent future problems related to the
Too many open files
error:- Add the following to
~/.bash_profile
or your desired shell configuration file:ulimit -n 8192
- close and reopen your current terminal window
- make sure that
ulimit -n
returns 8192
- Add the following to
-
Install the Xcode Command Line Tools:
xcode-select --install
Troubleshoot: command line tools already installed
If it complains
xcode-select: error: command line tools are already installed, use "Software Update" to install updates
, check to make sure XCode is downloaded and up to date manually. -
Install the Java 8 JDK:
brew cask install adoptopenjdk/openjdk/adoptopenjdk8
. More info here. -
Download and install Google Chrome, if you have not already. This is needed in order to be able to run apps tests locally.
Ubuntu 18.04 (Download iso)
Note: Virtual Machine Users should check the Alternative note below before starting
sudo apt-get update
sudo apt-get install -y git mysql-server mysql-client libmysqlclient-dev libxslt1-dev libssl-dev zlib1g-dev imagemagick libmagickcore-dev libmagickwand-dev openjdk-9-jre-headless libcairo2-dev libjpeg8-dev libpango1.0-dev libgif-dev curl pdftk enscript libsqlite3-dev build-essential redis-server rbenv chromium-browser parallel
- Hit enter and select default options for any configuration popups, leaving mysql passwords blank
- (If working from an EC2 instance)
sudo apt-get install -y libreadline-dev libffi-dev
- Install Node and Nodejs
- Install the latest version of Node Version Manager (nvm)
nvm install v8.15.0 && nvm alias default 8.15.0
Install nodejs v8.15.0node --version
Double check the version of node you are using. If it is wrong, then try restarting your terminal.
- Ensure rbenv and ruby-build are properly installed
- Use the rbenv-doctor from the
rbenv
installation instructions to verify rbenv is set up correctly:- curl -fsSL https://github.com/rbenv/rbenv-installer/raw/master/bin/rbenv-doctor | bash
- If there are any errors (they appear red), follow the [
rbenv
installation instructions] (https://github.com/rbenv/rbenv#basic-github-checkout) to properly configurerbenv
, following steps for Ubuntu Desktop so that config changes go into.bashrc
. - Install ruby-build as a rbenv plugin
- Use the rbenv-doctor from the
- Install Ruby 2.5.0 with rbenv
rbenv install 2.5.0
- If your PATH is missing
~/.rbenv/shims
, the next two commands might not work. Edit your .bashrc to include the following line:export PATH="$HOME/.rbenv/bin:~/.rbenv/shims:$PATH"
, then runsource .bashrc
for the change to take effect (as seen in this github issue). rbenv global 2.5.0
rbenv rehash
- Install yarn
curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | sudo apt-key add -
echo "deb https://dl.yarnpkg.com/debian/ stable main" | sudo tee /etc/apt/sources.list.d/yarn.list
sudo apt-get update && sudo apt-get install yarn=1.16.0-1
yarn --version
Double check the version of yarn is correct.
- Make it so that you can run apps tests locally
- Add the following to
~/.bash_profile
or your desired shell configuration file:export CHROME_BIN=$(which chromium-browser)
- Add the following to
- Finally, configure your mysql to allow for a proper installation. You may run into errors if you did not leave mysql passwords blank
echo "ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '';" | sudo mysql
- IMPORTANT: Read the following notes, then go back up to the overview and run the commands there.
- If, for any reason, you are forced to interrupt the
bundle exec rake install
command before it completes, cd into dashboard and runbundle exec rake db:drop
before tryingbundle exec rake install
again bundle exec rake install
must always be called from the local project's root directory, or it won't work.- Finally, don't worry if your versions don't match the versions in the overview if you're following this method; the installation should still work properly regardless
- If, for any reason, you are forced to interrupt the
Windows Subsystem for Linux (WSL) allows you to run a GNU/Linux environment directly on Windows without the overhead of a virtual machine. This is the easiest way to get Ruby and other prerequisites running on Windows.
It is worthwhile to make sure that you are using WSL 2. Attempting to use WSL 1 in the past resulted in errors with mysql and pdftk installation. In order to use WSL 2, you must be running Windows 10, updated to version 2004, Build 19041 or higher. If your Windows update service doesn't give you the update automatically, you can download it from the Windows download page.
- Enable WSL (unabridged WSL instructions here). You should run Powershell as Administrator for the following commands:
dism.exe /online /enable-feature /featurename:Microsoft-Windows-Subsystem-Linux /all /norestart
dism.exe /online /enable-feature /featurename:VirtualMachinePlatform /all /norestart
- Restart your machine. WSL 2 will be the default if your Windows version is sufficiently updated.
wsl --set-default-version 2
- You may need to update the WSL 2 Linux kernel
- Install Ubuntu 20.04 (Windows Store link)
- If you want to follow the Ubuntu setup exactly, Ubuntu 18.04 is available from the Microsoft docs.
- Make sure virtualization is turned on your BIOS settings.
- From the command line, run
wsl
, or from the Start menu, find and launch 'Ubuntu'. When this runs for the first time, WSL will complete installation in the resulting terminal window.
From here, you can follow the Ubuntu procedure above, with the following observations...
- In step 2, you may run into the error
E: Unable to locate package openjdk-9-jre-headless
. This is because openjdk-9 has been superseded by openjdk-11. Replaceopenjdk-9-jre-headless
withopenjdk-11-jre-headless
. If you want, you can first check to see if this replacement package is available on your distro usingsudo apt-cache search openjdk
as per this StackOverflow thread. chromium-browser
might not work with the error messageCommand '/usr/bin/chromium-browser' requires the chromium snap to be installed.
. You can instead install chrome by running the following:wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb
sudo apt install ./google-chrome-stable_current_amd64.deb
- modify step 8 of the Ubuntu instructions to read
export CHROME_BIN=$(which google-chrome)
- Before step 9, you may have to restart MySQL using
sudo /etc/init.d/mysql restart
...followed by the overview instructions, with the following observation:
- Before running
bundle exec rake install
, you may have to start the mysql service:sudo service mysql start
- Option A: Use VMWare Player or Virtual Box and an Ubuntu 18.04 iso image
- Maximum Disk Size should be set to at least 35.0 GB (the default is 20 GB and it is too small)
- Memory Settings for the VM should be 8 GB or higher (Right click the machine -> Settings -> "Memory for this virtual machine" )
- Option B: Use vagrant (install):
- First clone the code.org git repo to get the provided Vagrantfile (you will be able to skip step 1 of the common setup instructions):
git clone https://github.com/code-dot-org/code-dot-org.git
cd code-dot-org
vagrant up
vagrant ssh
- Goto step 2 of the common setup instructions
- First clone the code.org git repo to get the provided Vagrantfile (you will be able to skip step 1 of the common setup instructions):
- Option C: Use an Amazon EC2 instance:
- Request AWS access from [email protected] if you haven't already done so.
- From the EC2 Homepage, click on "Launch Instance" and follow the wizard:
- Step 1: Choose AMI: Select Ubuntu Server 18.04
- Step 2: Choose instance type: Choose at least 8GiB memory (e.g.
t2.large
) - Step 3: Configure Instance: Set IAM Role to
DeveloperEC2
- Step 4: Storage: Increase storage to 100GiB
- Launch the instance. When asked for a key pair, you can create a new key pair (be sure to download and save the .pem file) or use an existing key pair that you have the .pem file for.
- Connect to the instance by selecting the instance in the AWS EC2 dashboard and clicking "Connect". Follow the provided instructions in order to connect via ssh or PuTTY. Upon completing this step, you should be able to connect to your instance via a command like
ssh -i <keyname>.pem <public-dns-name>
. - Optionally, update your ssh config so that you can connect using a shorter command:
- move your private key to
~/.ssh/<keyname>.pem
- add the following lines to ~/.ssh/config:
Host yourname-ec2 Hostname <public-dns-name> User ubuntu PreferredAuthentications publickey IdentityFile ~/.ssh/<keyname>.pem
- run
ssh yourname-ec2
to connect to your instance
- move your private key to
- Go back up to the overview and run the commands there.
- Once you have successfully completed
bundle exec rake build
, you can connect to it as follows:- run
ssh -L 3000:127.0.0.1:3000 yourname-ec2
and then~/code-dot-org/bin/dashboard-server
on your local machine. This sets up SSH port forwarding from your local machine to your ec2 dev instance for as long as your ssh connection is open. - navigate to http://localhost-studio.code.org:3000/ on your local machine
- run
If you want the Code.org repo to point to the local version of the Piskel you are working on, your apps package must be linked to a local development copy of the Piskel repository with a complete dev build.
You can also find the steps below in apps/Gruntfile.js of the code-dot-org repo
git clone https://github.com/code-dot-org/piskel.git <new-directory>
cd <new-directory>
npm install && grunt build-dev
npm link
cd <code-dot-org apps directory>
npm link @code-dot-org/piskel
- rerun
yarn start
in the<code-dot-org apps directory>
- If you try grunt serve and it is aborted due to warnings do
grunt serve --force
Note: the installation process now enables this by default, which is recommended. You can manually edit these values later if you want to disable local JS builds.
If you want to make JavaScript changes and have them take effect locally, you'll want to enable local builds of the JavaScript packages. You'll need to do this once:
-
Edit locals.yml and enable the following options:
# code-dot-org/locals.yml # These enable the local apps build build_apps: true use_my_apps: true
-
Run
bundle exec rake package
for the changes to take effect.
This configures dashboard to rebuild apps whenever you run bundle exec rake build
and to use the version that you built yourself. See the documentation in that directory for faster ways to build and iterate.
We enforce linting rules for all our code, and we recommend you set up your editor to integrate with that linting.
We use eslint to lint our Javascript; see the official integrations guide for instructions for your editor of choice.
Our lint configuration uses formatting rules provided by Prettier. You can configure your editor to auto-format your code to meet our requirements, in addition to the error highlighting provided by eslint. See the official integrations guide for instructions for your editor of choice.
We use RuboCop to lint our Ruby; see the official integrations guide for instructions for your editor of choice.
Please also see our other documentation, including our:
Wondering where to start? See our contribution guidelines for more information on helping us out.
If rmagick doesn't install, check your version of imagemagick, and downgrade if >= 7
convert --version
brew install imagemagick@6
brew unlink imagemagick
brew link imagemagick@6 --force
If you continue to have issues with rmagick, after changing your imagemagick version, you may need to uninstall/reinstall the gemgem uninstall rmagick
gem install rmagick -v 2.16.0
Note: Most developers won't need to peronsonalize certificates locally, but some will. Here are notes on getting this working on macOS.
Certificates have been greatly improved with the ability to apply text in many languages.
This is done by using “pango”. It seems on Linux machines, ImageMagick already contains Pango, but on macOS it doesn’t... at least as installed using brew.
So we need to install a version of ImageMagick that includes Pango. There are tons of threads online where people can’t get it to work.
The good news is that we figured out a solution.
First modify the ImageMagick formula in brew, using
brew edit imagemagick
Note that one developer found they needed to brew edit imagemagick@6
.)
Change --without-pango
to --with-pango
. However, that’s not enough. Add
depends_on "pango"
near the similar entries. This is the step that we couldn’t find online anywhere.
Then
brew uninstall imagemagick
(Note that one developer found they needed to and brew uninstall imagemagick@6
.)
Then
brew install imagemagick@6 --build-from-source
Then, because it’s @6
, we need to
brew link imagemagick@6 --force
to make it generally accessible from both the command line and from rmagick.
(We still use imagemagick@6
because we need magicwand, whatever that is.)
Now, we have Pango in our ImageMagick, which we can test with
convert pango:"test text" test.png
Finally, it’s likely that we now have a slightly different version of ImageMagick. We need rmagick to rediscover that with
bundle remove rmagick
bundle add rmagick
Restart dashboard-server
and if all went well, we see text rendering on customized certificates again.
If you run into an error with libv8 while running bundle install
- Uninstall libv8:
gem uninstall libv8
- Make sure the gem no longer exists with:
gem list libv8
- Install the current version used in code.org repo:
gem install libv8 -v CURRENT_CODEORG_VERSION -- --with-system-v8
(you can find what to fill in for CURRENT_CODEORG_VERSION as the current version of libv8 in the Gemfile.lock).
If you run into an issue about mysql2 while running bundle install
and the error output includes "ld: library not found for -lssl" try :
brew install openssl
export LIBRARY_PATH=$LIBRARY_PATH:/usr/local/opt/openssl/lib/
(Steps from this github issue)
If you run into an issue about therubyracer while running bundle install
try :
gem uninstall libv8
gem install therubyracer -v CURRENT_CODEORG_VERSION
(you can find what to fill in for CURRENT_CODEORG_VERSION as the current version of the therubyracer in the Gemfile.lock).gem install libv8 -v CURRENT_CODEORG_VERSION -- --with-system-v8
(You can find what to fill in for CURRENT_CODEORG_VERSION as the current version of libv8 in the Gemfile.lock).
(Steps from this stackoverflow question)
If you run into the error message can't find gem bundler (>= 0.a) with executable bundler (Gem::GemNotFoundException)
while running bundle install
try (as seen in this StackOverflow):
gem install bundler -v BUNDLED_WITH_VERSION
, where the version is theBUNDLED WITH
version in Gemfile.lock).bundle install
If you run into error messages about implicit declaration of function thin_xxx
when trying to compile the native extensions for thin:
gem install thin -v THIN_VERSION -- --with-cflags="-Wno-error=implicit-function-declaration"
where THIN_VERSION is the current version of thin in Gemfile.lock).
(More info here)
If you run into an error message about Could not find MIME type database in the following locations...
while installing the mimemagic
gem, try:
brew install shared-mime-info
(More info on mimemagic dependencies here, including help for OSes that don't support Homebrew.)
OS X: when running bundle install
, you may need to also run xcode-select --install
. See stackoverflow. If this doesn't work, step 9 in the overview will not run correctly. In that case run the following command in the Terminal (found from
nodejs/node-gyp#569): sudo xcode-select -s /Applications/Xcode.app/Contents/Developer
While it's possible to run the server locally without these, we've found the following hardware specifications to be best for fast development.
- Memory: minimum of 8GB RAM for
dashboard-server
andyarn
- Storage: The repository takes up 20GB