Development Environment Setup

The first step to contributing to the code base is creating your development environment.

Git Setup

SymPy is available on GitHub and uses Git for source control. The workflow is such that code is pulled and pushed to and from the main repository. Install the respective version of Git for your operating system to start development.

Note

Refer to the installation instructions in the Git installation instructions. Learn about the basic git commands in this Git Handbook or any other sources on the internet.

Get the SymPy Code

It is recommended practice to create a fork of the SymPy project for your development purposes. Create your own fork of the SymPy project (if you have not yet). Go to the SymPy GitHub repository:

https://github.com/sympy/sympy

You will now have a fork at <https://github.com/<your-user-name>/sympy>.

Then, nn your machine browse to where you would like to store SymPy, and clone (download) the latest code from SymPy’s original repository (about 77 MiB):

$ git clone https://github.com/<your-user-name>/sympy

You must configure the remote repositories for collaboration with the upstream project:

$ cd sympy
$ git remote add upstream https://github.com/sympy/sympy

After the configuration, your setup should be similar to this:

$ git remote -v
origin       https://github.com/<your-user-name>/sympy (fetch)
origin       https://github.com/<your-user-name>/sympy (push)
upstream     https://github.com/sympy/sympy (fetch)
upstream     https://github.com/sympy/sympy (push)

For further development, it is recommended to create a development branch.

$ git checkout -b dev-branch

The new branch can be of any name.

Virtual Environment Setup

You may want to take advantage of using virtual environments to isolate your development version of SymPy from any system wide installed versions, e.g. from apt-get install python-sympy.

We recommend using conda to create a virtual environment:

$ conda create -n sympy-dev python=3 mpmath flake8

You now have a environment that you can use for testing your development copy of SymPy. For example, clone your SymPy fork from Github:

$ git clone git@github.com:<your-github-username>/sympy.git
$ cd sympy

Now activate the environment:

$ conda activate sympy-dev

Run the Tests

There are several ways of running SymPy tests but the easiest is to use the bin/test script, consult ‘the wiki details on running tests <https://github.com/sympy/sympy/wiki/Running-tests>`_.

The script takes a number of options and arguments and then passes them to sympy.test(*paths, **kwargs). Run bin/test --help for all supported arguments.

Run all tests by using the command:

$ bin/test

To run tests for a specific file, use:

$ bin/test test_basic

Where test_basic is from file sympy/core/basic.py.

To run tests for modules, use:

$  bin/test /core /utilities

This will run tests for the core and utilities modules.

Similary, run quality tests with:

$ bin/test code_quality