Skip to content

Latest commit

 

History

History
149 lines (99 loc) · 4.2 KB

setup.md

File metadata and controls

149 lines (99 loc) · 4.2 KB

Setting Up a Development Environment

The following commands should work in a Unix shell (Bash or ZSH for example) and in Windows PowerShell.

Install requirements

Windows

If you don't own a Windows license but you still need to build / test the app on Windows, you can use the free virtual machines provided by Microsoft, either in VirtualBox or any of the hypervisors supporting the available VM file formats.

The following assumes you run commands from an administrator command prompt

To get an administrator prompt, look for Command Prompt in the start menu, right-click on it and select Run as administrator.

Once you are in a running Windows session, you can eventually install Chocolatey from an administrator prompt, then use it to install the requirements above (or you can download and install each of the installers):

choco install git
choco install nodejs-lts
choco install yarn

Right now the nodejs-lts package seems to be broken, you may need to install the latest Node 6.x by hand.

You may also need at some point to restart the Command Prompt, the whole system, or refresh your environment variables using therefreshenv command.

Then install the Windows build tools from an admin console as documented in the Microsoft's Node.js guidelines:

npm install -g windows-build-tools

You may still need to manually add the python installation directory to your PATH. To do so, search for PATH from the start menu and select Edit environment variables for your account. Then edit the PATH user variable (not the system one) and append the following to the end (assuming ... is the current text):

`...;%USERPROFILE%\.windows-build-tools\python27`

To set up Docker, in case you hardware is old or you don't own a Windows Pro license, you may encounter the same issue as on old macOS hardware (see below). (please feel free to improve this section)

macOS

You need a Mac to build / test for macOS.

The easiest way to set up the environment is to install and use Homebrew:

brew install git
brew install node
brew install yarn

To install Docker, first check that your mac has kernel hypervisor support:

sysctl -n kern.hv_support

If the output is 1, then you can install the latest Docker version:

brew cask install docker

Otherwise you'll have to install a Docker VM and set up your shell environment so the various docker commands know how to use it (you can omit the default parameters below):

brew cask install docker-toolbox
docker-machine create default
eval $(docker-machine env default)

Fedora 27

sudo dnf install docker gcc-c++ git nodejs
cd /etc/yum.repos.d/
sudo wget https://dl.yarnpkg.com/rpm/yarn.repo
cd -
sudo dnf install yarn

Get the code

git clone [email protected]:cozy-labs/cozy-desktop.git
cd cozy-desktop

Install dependencies

yarn install

Set up a Cozy stack

If you don't already have a running Cozy stack, the easiest way to get started is to use Docker:

cd cli
docker-compose up
yarn bootstrap

Otherwise, please refer to the ../../cli/dev/docker/bootstrap-cozy-desktop.sh script to create the appropriate instances, token, etc...

Build everything

yarn build

Run tests

See ./test.md.

Cozy Stack

You can run any command in the cozy-stack docker container with the yarn docker:exec script, e.g.:

yarn docker:exec apt-get update
yarn docker:exec apt-get install git  # So we can install cozy apps

You can also run any cozy-stack command with the yarn cozy-stack script, e.g.:

yarn cozy-stack apps install --domain cozy.tools:8080 drive 'git://github.com/cozy/cozy-drive.git#build-drive'