-
Notifications
You must be signed in to change notification settings - Fork 135
Home
The best source for general ODP information is opendataplane.org, this wiki focuses on development related subjects.
This repository contains the odp-linux implementation of the ODP API. It’s focus is to provide a clear reference implementation of the ODP API rather than a performance optimal implementation on a given platform. Other implementations can be found at Platform specific implementations.
GitHub Actions CI uses Docker containers to fill the following requirements:
-
Not relay on distro package hosting.
-
Be able to locally reproduce any CI run task.
To build and upload Docker images we use odp-docker-images repository. The distribution environments are described in the Dockerfiles. There is also a very simple .travis.yml
file to build images.
To run Docker locally:
-
install Docker (apt-get install docker.io)
-
cd to ODP source directory
-
copy and paste a run command from a GitHub Actions run, for example:
docker run -i -t -v `pwd`:/odp --shm-size 8g -e CC=clang opendataplane/travis-odp-ubuntu_18.04-x86_64 /odp/scripts/ci/build_x86_64.sh
Where:
-
-i - means interactive. (For debug you can specify /bin/bash and run /odp/scripts/ci/build_x86_64.sh manually inside container. All container data will be lost on exit.)
-
-t, --tty Allocate a pseudo-TTY to make output visible on stdout,stderr.
-
-v
pwd
:/odp - means pass current host directory to container. (Directory is rw shared between host and container.) -
-e CC=clang - pass environment variable inside container
-
opendataplane/travis-odp-ubuntu_18.04-x86_64 - container name on hub.docker.com to run
-
/odp/scripts/ci/build_x86_64.sh - the latest parameter is command to run after container started.
To run CI on custom images you need:
-
Create account on hub.docker.com
-
Fork https://github.com/OpenDataPlane/odp-docker-images project to your local name space.
-
Build and upload custom images under your Docker name space
-
In you ODP project, in Travis web interface settings specify DOCKER_NAMESPACE pointing to your account on hub.docker.com.
Note: Docker downloads and prepares images on the first run. Like git you need to do periodic 'docker pull' images in case new images were updated on cloud server.
Details on regression, go to site.
Details on regression, go to site.
Detailed analysis, go to site.