Skip to main content

Sample Travis CI + Pypi integration

Project description

Travis CI + Pypi Integration Guide
=====================================

This is a very short guide to using Travis CI with your GitHub hosted code repository
to automatically deploy a python package to Pypi.
If you’re new to continuous integration or would like some more information on what Travis CI does,
read `Travis CI Core Concepts for Beginners <https://docs.travis-ci.com/user/for-beginners>`_ first.

In this guide, we will be creating a Travis CI pipeline to automatically:

- Start mongodb service. Requires ``mongo>=4.0``
- Run ``pytest`` tests
- Distributes the package to pypi

All the code can be found on https://github.com/musyoka-morris/travis-pypi-integration

Prerequisites
******************

To proceed, make sure you have a Travis CI account.
You can easily create one by visiting https://travis-ci.org/ and then click the ``Sign in with Github`` button.

1. Install Travis CLI
***********************

First we need to install ``Travis CLI`` which is written in Ruby and published as a gem.
We will be using this tool to encrypt the Pypi password.


To install the gem:

sudo gem install travis

ERROR: can't find header files for ruby ...
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

If you run into the error **can't find header files for ruby**,
then you also need to have the ruby headers installed.

The `stack overflow answer <https://stackoverflow.com/questions/4304438/gem-install-failed-to-build-gem-native-extension-cant-find-header-files/4502672#4502672>`_
saved me. In summary, you need to install ruby development headers as follows:

For Debian, and other distributions using Debian style packaging:

sudo apt-get install ruby-dev

For Ubuntu:

sudo apt-get install ruby-all-dev

2. Create a .travis.yml file
******************************

.travis.yml
------------

.. code-block:: yaml

language: python # We are using Python language
install: pip install -r requirements.txt # Install requirements
script: pytest # Run pytest tests

MongoDB service
------------------

Add instructions to start mongodb service.

This section is optional if you are not interested in MongoDB service.
I simply left it here to serve as a guide for other services of interest.

.. code-block:: yaml

...
services:
- mongodb
before_script:
- sleep 15 # Sleep for 15 seconds to ensure the service is started before we issue any commands

By default, travis loads ``mongo v2.4``. We instruct travis to load mongo v4.0

.. code-block:: yaml

...
dist: xenial
addons:
apt:
sources:
- mongodb-4.0-xenial # As defined on Travis Source safelist

Pypi Deployment
-----------------

Add instruction for deployment to pypi

.. code-block:: yaml

...
deploy:
provider: pypi
user: musyoka-morris # Replace this with your pypi username. Password will be provided later
distributions: sdist bdist_wheel
skip_existing: true

3. Add encrypted pypi password
********************************

Notice that so far we have not specified our pypi password.
The easiest way to add the password encrypted with the public key is to use Travis CLI:

travis encrypt Your-Password-Here --add deploy.password

Note: This assumes you are running the command in your project directory. If not, add ``-r owner/project``.

The command automatically adds your encrypted password on the .travis.yml file.
your .travis.yml file should look like this:

.. code-block:: yaml

...
deploy:
...
user: musyoka-morris
password:
secure: YourEncryptedPasswordHere


4. Push to GIT
****************

Travis configuration is ready.
Simply push the code to the master branch and Travis will take care of the rest.


The complete ``.travis.yml`` file can be found on Github https://github.com/musyoka-morris/travis-pypi-integration

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

travis_pypi_integration-2.1.1.tar.gz (3.5 kB view details)

Uploaded Source

Built Distribution

travis_pypi_integration-2.1.1-py3-none-any.whl (4.3 kB view details)

Uploaded Python 3

File details

Details for the file travis_pypi_integration-2.1.1.tar.gz.

File metadata

  • Download URL: travis_pypi_integration-2.1.1.tar.gz
  • Upload date:
  • Size: 3.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.7

File hashes

Hashes for travis_pypi_integration-2.1.1.tar.gz
Algorithm Hash digest
SHA256 c69fa22262102600141cc48b930de8689ecd241ad90fb61265bd8cc815214c92
MD5 3beb4a3c3838fb9d92326b91907dbe04
BLAKE2b-256 4a5d527a69a8af55f229770ab0f22c050165cffc5cc74376b79105649e756747

See more details on using hashes here.

File details

Details for the file travis_pypi_integration-2.1.1-py3-none-any.whl.

File metadata

  • Download URL: travis_pypi_integration-2.1.1-py3-none-any.whl
  • Upload date:
  • Size: 4.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.7

File hashes

Hashes for travis_pypi_integration-2.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 caabbf10e54b0361137385a384a195ead202d4c2539690109e85b65928c0854a
MD5 9bc08c6b5dbc14fc1125f984f465bef9
BLAKE2b-256 2928c54a3ec9292109453c829d428ce86e2be0714fd031b683ca5bbd223dc7ac

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page