Module: Kitchen::Docker::Helpers::DockerfileHelper
- Includes:
- Configurable
- Included in:
- Container::Linux
- Defined in:
- lib/kitchen/docker/helpers/dockerfile_helper.rb
Instance Method Summary collapse
- #almalinux_platform ⇒ Object
- #arch_platform ⇒ Object
- #centosstream_platform ⇒ Object
- #debian_platform ⇒ Object
- #dockerfile_base_linux(username, homedir) ⇒ Object
- #dockerfile_platform ⇒ Object
- #fedora_platform ⇒ Object
- #gentoo_paludis_platform ⇒ Object
- #gentoo_platform ⇒ Object
- #opensuse_platform ⇒ Object
- #photonos_platform ⇒ Object
- #rhel_platform ⇒ Object
Instance Method Details
#almalinux_platform ⇒ Object
133 134 135 136 137 138 139 140 141 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 133 def almalinux_platform " ENV container docker\n RUN yum clean all\n RUN yum install -y sudo openssh-server openssh-clients which\n RUN [ -f \"/etc/ssh/ssh_host_rsa_key\" ] || ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key -N ''\n RUN [ -f \"/etc/ssh/ssh_host_dsa_key\" ] || ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key -N ''\n CODE\nend\n" |
#arch_platform ⇒ Object
50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 50 def arch_platform # See https://bugs.archlinux.org/task/47052 for why we # blank out limits.conf. " RUN pacman --noconfirm -Sy archlinux-keyring\n RUN pacman-db-upgrade\n RUN pacman --noconfirm -Syu openssl openssh sudo curl\n RUN [ -f \"/etc/ssh/ssh_host_rsa_key\" ] || ssh-keygen -A -t rsa -f /etc/ssh/ssh_host_rsa_key\n RUN [ -f \"/etc/ssh/ssh_host_dsa_key\" ] || ssh-keygen -A -t dsa -f /etc/ssh/ssh_host_dsa_key\n RUN echo >/etc/security/limits.conf\n CODE\nend\n" |
#centosstream_platform ⇒ Object
123 124 125 126 127 128 129 130 131 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 123 def centosstream_platform " ENV container docker\n RUN yum clean all\n RUN yum install -y sudo openssh-server openssh-clients which\n RUN [ -f \"/etc/ssh/ssh_host_rsa_key\" ] || ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key -N ''\n RUN [ -f \"/etc/ssh/ssh_host_dsa_key\" ] || ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key -N ''\n CODE\nend\n" |
#debian_platform ⇒ Object
63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 63 def debian_platform disable_upstart = " RUN [ ! -f \"/sbin/initctl\" ] || dpkg-divert --local --rename --add /sbin/initctl \\\n && ln -sf /bin/true /sbin/initctl\n CODE\n packages = <<-CODE\n ENV DEBIAN_FRONTEND noninteractive\n ENV container docker\n RUN apt-get update\n RUN apt-get install -y sudo openssh-server curl lsb-release\n CODE\n config[:disable_upstart] ? disable_upstart + packages : packages\nend\n" |
#dockerfile_base_linux(username, homedir) ⇒ Object
153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 153 def dockerfile_base_linux(username, homedir) " RUN if ! getent passwd \#{username}; then \\\n useradd -d \#{homedir} -m -s /bin/bash -p '*' \#{username}; \\\n fi\n RUN mkdir -p /etc/sudoers.d\n RUN chmod 0750 /etc/sudoers.d\n RUN echo \"\#{username} ALL=(ALL) NOPASSWD: ALL\" >> /etc/sudoers.d/\#{username}\n RUN echo \"Defaults !requiretty\" >> /etc/sudoers.d/\#{username}\n RUN mkdir -p \#{homedir}/.ssh\n RUN chown -R \#{username} \#{homedir}/.ssh\n RUN chmod 0700 \#{homedir}/.ssh\n RUN touch \#{homedir}/.ssh/authorized_keys\n RUN chown \#{username} \#{homedir}/.ssh/authorized_keys\n RUN chmod 0600 \#{homedir}/.ssh/authorized_keys\n RUN mkdir -p /run/sshd\n CODE\nend\n" |
#dockerfile_platform ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 23 def dockerfile_platform case config[:platform] when 'arch' arch_platform when 'debian', 'ubuntu' debian_platform when 'fedora' fedora_platform when 'gentoo' gentoo_platform when 'gentoo-paludis' gentoo_paludis_platform when 'opensuse/tumbleweed', 'opensuse/leap', 'opensuse', 'sles' opensuse_platform when 'rhel', 'centos', 'oraclelinux', 'amazonlinux', 'rockylinux' rhel_platform when 'centosstream' centosstream_platform when 'almalinux' almalinux_platform when 'photon' photonos_platform else raise ActionFailed, "Unknown platform '#{config[:platform]}'" end end |
#fedora_platform ⇒ Object
77 78 79 80 81 82 83 84 85 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 77 def fedora_platform " ENV container docker\n RUN dnf clean all\n RUN dnf install -y sudo openssh-server openssh-clients which curl\n RUN [ -f \"/etc/ssh/ssh_host_rsa_key\" ] || ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key -N ''\n RUN [ -f \"/etc/ssh/ssh_host_dsa_key\" ] || ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key -N ''\n CODE\nend\n" |
#gentoo_paludis_platform ⇒ Object
96 97 98 99 100 101 102 103 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 96 def gentoo_paludis_platform " RUN cave sync\n RUN cave resolve -zx net-misc/openssh app-admin/sudo\n RUN [ -f \"/etc/ssh/ssh_host_rsa_key\" ] || ssh-keygen -A -t rsa -f /etc/ssh/ssh_host_rsa_key\n RUN [ -f \"/etc/ssh/ssh_host_dsa_key\" ] || ssh-keygen -A -t dsa -f /etc/ssh/ssh_host_dsa_key\n CODE\nend\n" |
#gentoo_platform ⇒ Object
87 88 89 90 91 92 93 94 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 87 def gentoo_platform " RUN emerge-webrsync\n RUN emerge --quiet --noreplace net-misc/openssh app-admin/sudo\n RUN [ -f \"/etc/ssh/ssh_host_rsa_key\" ] || ssh-keygen -A -t rsa -f /etc/ssh/ssh_host_rsa_key\n RUN [ -f \"/etc/ssh/ssh_host_dsa_key\" ] || ssh-keygen -A -t dsa -f /etc/ssh/ssh_host_dsa_key\n CODE\nend\n" |
#opensuse_platform ⇒ Object
105 106 107 108 109 110 111 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 105 def opensuse_platform " ENV container docker\n RUN zypper install -y sudo openssh which curl\n RUN /usr/sbin/sshd-gen-keys-start\n CODE\nend\n" |
#photonos_platform ⇒ Object
143 144 145 146 147 148 149 150 151 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 143 def photonos_platform " ENV container docker\n RUN tdnf clean all\n RUN tdnf install -y sudo openssh-server openssh-clients which curl\n RUN [ -f \"/etc/ssh/ssh_host_ecdsa_key\" ] || ssh-keygen -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key -N ''\n RUN [ -f \"/etc/ssh/ssh_host_ed25519_key\" ] || ssh-keygen -t ed25519 -f /etc/ssh/ssh_host_ed25519_key -N ''\n CODE\nend\n" |
#rhel_platform ⇒ Object
113 114 115 116 117 118 119 120 121 |
# File 'lib/kitchen/docker/helpers/dockerfile_helper.rb', line 113 def rhel_platform " ENV container docker\n RUN yum clean all\n RUN yum install -y sudo openssh-server openssh-clients which curl\n RUN [ -f \"/etc/ssh/ssh_host_rsa_key\" ] || ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key -N ''\n RUN [ -f \"/etc/ssh/ssh_host_dsa_key\" ] || ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key -N ''\n CODE\nend\n" |