Skip to content

TripleParity/docker-api-to-compose

Repository files navigation

docker-api-to-compose

codecov Build Status Maintainability Test Coverage

Generate docker-compose files from Docker API inspect output.

Features

  • Accepts JSON data from docker API v1.37
  • Generates v3.3 docker-compose.yml files

Usage

// TODO: Is this line correct?
import { compose, getNetworkIds, getVolumeNames } from 'docker-api-to-compose';

const services = getServicesInStack('MyCoolStack');

const networkIds = getNetworkIds(services);
const networks = inspectNetworks(networkIds);

const volumeNames = getVolumeNames(services);
const volumes = inspectVolumes(volumes);

const stackFile = compose(services, networks, volumes);

Docker Compose Features

Crossed out features are not compatible with Docker Swarm.

  • build
  • cap_add, cap_drop
  • command
  • configs (priority)
    • Short syntax
    • Long syntax
  • cgroup_parent
  • container_name
  • credential_spec (3.3+)
  • deploy (3 only)
    • endpoint_mode (3.3 only)
    • labels
    • mode
    • placement
      • constraints
      • preferences
    • replicas
    • resources (priority)
    • restart_policy
    • rollback_config (3.7+)
    • update_config
  • devices
  • depends_on
  • dns
  • dns_search
  • tmpfs (3.6+)
  • entrypoint
  • env_file
  • environment
  • expose (priority)
  • external_links
  • extra_hosts
  • healthcheck
  • image
  • init (3.7+)
  • isolation
  • labels
  • links
  • logging (priority)
  • network mode
  • networks
    • aliases
    • ipv4_address, ipv6_address
  • pid
  • ports
    • Short syntax
    • Long syntax (3.2+)
  • secrets (priority)
    • Short syntax
    • Long syntax
  • security_opt
  • stop_grace_period
  • stop_signal
  • sysctls
  • ulimits
  • userns_mode
  • volumes
    • Short syntax
      • access mode
    • Long syntax (3.2+)
      • type
      • source
      • target
      • read_only
      • bind
        • propagation
      • volume
        • nocopy
      • tmpfs
        • size
    • Caching options for volume mounts (Docker for Mac)
  • domainname, hostname, ipc, mac_address, privileged, read_only, shm_size, stdin_open, tty, user, working_dir
  • Volume configuration reference
    • driver
    • driver_opts
    • external (deprecated in 3.4, use name instead)
    • labels
    • name (3.4+)
  • Network configuration reference
    • driver
      • bridge
      • overlay
      • host or none
    • driver_opts
    • attachable (3.2+)
    • enable_ipv6
    • ipam
    • internal
    • labels
    • external (deprecated in 3.5, use name instead)
    • name (3.5+)
  • configs configuration reference
  • secrets configuration reference

Testing Process

The tests were developed using the following process:

  1. Writing test_x.yml
  2. docker stack deploy -c test_x.yml test_x
  3. curl --no-buffer -XGET --unix-socket /var/run/docker.sock http:/v1.37/services/test_x_MyServiceName | python -m json.tool --> test_x.json
  4. curl --no-buffer -XGET --unix-socket /var/run/docker.sock http:/v1.37/networks/text_x_default | python -m json.tool --> test_x_net.json
    • Repeat for other networks
  5. curl --no-buffer -XGET --unix-socket /var/run/docker.sock http:/v1.37/volumes/test_x_volumeName | python -m json.tool --> test_x_vol.json
    • Repeat for other volumes
  6. npm run test

A More automated method (that requires root) could be

  1. Write test_x_src.yml file to be used for deploying
  2. Write test_x.yml to be used as expected output
  3. Deploy test_x_src.yml
  4. Use a script to get related networks and services
  5. Compose stack file
  6. Compare stack files

Things that are not so great

  • Expected yml requires specific order of keys
  • Expected yml tests multiple functions