Diff for "yellow/ParallelTestingSetupForDataCentre"

Not logged in - Log In / Register

Differences between revisions 3 and 20 (spanning 17 versions)
Revision 3 as of 2012-07-31 16:02:30
Size: 4055
Editor: bac
Comment:
Revision 20 as of 2012-08-29 16:14:54
Size: 4235
Editor: frankban
Comment:
Deletions are marked like this. Additions are marked like this.
Line 13: Line 13:
 1. Setup host using puppet (as above)
=== Setup host as root ===
Line 15: Line 17:
     apt-add-repository ppa:yellow/ppa
     apt-add-repository deb http://us.archive.ubuntu.com/ubuntu/ lucid main universe
     apt-get install ssh bzr apache2.2-common buildbot/lucid testrepository haveged subunit lxc libvirt-bin
     apt-add-repository ppa:launchpad/ppa
     apt-add-repository "deb http://us.archive.ubuntu.com/ubuntu/ lucid main universe"
     apt-get update
     apt-get install ssh bzr apache2.2-common buildbot/lucid testrepository haveged subunit lxc libvirt-bin lpsetup
Line 19: Line 22:
  1. Install buildbot from {{{lp:~launchpad/lpbuildbot/public/}}}
Line 26: Line 28:
  1. Install buildbot from {{{http://bazaar.launchpad.net/~launchpad/lpbuildbot/public}}}
Line 31: Line 34:
    ln -s /etc/apparmor.d/usr.bin.lxc-start /etc/apparmor.d/usr.bin.lxc-start /etc/apparmor.d/disable/     ln -s /etc/apparmor.d/usr.bin.lxc-start /etc/apparmor.d/disable/
Line 39: Line 42:
  1. Authorize root connections to the LXC:<<BR>>{{{   1. Authorize root connections to the LXC: <<BR>>{{{
Line 55: Line 58:

It is possible to connect via ssh to the container using:
{{{ssh -i ~buildbot/.ssh/launchpad_lxc_id_rsa `lp-lxc-ip -n lptests -i eth0`}}}

=== Inside the container as root ===
Line 63: Line 71:
    lp-setup init-host --yes -u buildbot -S launchpad_lxc_id_rsa --skip-steps setup_home}}}
 1. Inside container as buildbot
  1. {{{lp-setup init-repo --yes --use-http --no-checkout}}}
  1. {{{lp-setup update ~buildbot/launchpad/lp-branches/devel --use-http}}}
 1. Inside container as root:
  1. {{{lp-setup finish-init-host ~buildbot/launchpad/lp-branches/devel --user buildbot --yes}}}
    lp-setup init-target --yes -u buildbot -S launchpad_lxc_id_rsa --skip-steps setup_home -f "Launchpad PQM" -E launchpad-pqm@canonical.com}}}

=== Inside the container as buildbot ===
  1. {{{lp-setup init-repo --yes --use-http --no-checkout -r ~/slaves/slave}}}
  1. {{{lp-setup update ~/slaves/slave/devel --use-http}}}

=== Inside the container as root, again ===

Setting up the Launchpad machine for parallel testing

The Yellow Squad has developed a tool called lpsetup to replace the original rocketfuel-* scripts that were used by Launchpad developers to get the required pieces needed to begin contributing to Launchpad. While rocketfuel was written for that single purpose, lpsetup has another mission, which is to allow the complete set up and running of buildbot for parallel testing on EC2 or locally on LXC.

Create buildbot slave?

Assumptions

  • No use of the juju charms at all.
  • lpsetup can only be run inside the LXC.
  • Root changes on the host will only be done via puppet scripts written by IS.

Steps

Setup host as root

  1. Install required packages and PPAs

         apt-add-repository ppa:launchpad/ppa
         apt-add-repository "deb http://us.archive.ubuntu.com/ubuntu/ lucid main universe"
         apt-get update
         apt-get install ssh bzr apache2.2-common buildbot/lucid testrepository haveged subunit lxc libvirt-bin lpsetup
  2. Make buildbot user/group as needed

        # Some versions of LXC require the user to have a group.  Bug #942850.
        addgroup buildbot
        usermod --gid buildbot buildbot
        usermod -s /bin/sh buildbot
  3. Install buildbot from http://bazaar.launchpad.net/~launchpad/lpbuildbot/public

  4. Generate ssh keys for buildbot user named launchpad_lxc_id_rsa

  5. ssh-keyscan -t rsa bazaar.launchpad.net >> ~buildbot/.ssh/known_hosts

  6. Add new public key to ~buildbot/.ssh/authorized_keys

  7. Set up bzr whoami: bzr whoami “Launchpad PQM  <launchpad-pqm@canonical.com>“

  8. Disable apparmor profiles for lxc:

        ln -s /etc/apparmor.d/usr.bin.lxc-start /etc/apparmor.d/disable/
        apparmor_parser -R /etc/apparmor.d/usr.bin.lxc-start
  9. Create /etc/lxc/lp-setup.conf:

        lxc.network.type = veth
        lxc.network.link = lxcbr0
        lxc.network.flags = up
  10. Create an LXC named “lptests”: lxc-create -t ubuntu -n lptests -f  /etc/lxc/lp-setup.conf -- -r lucid -a i386 -b buildbot

  11. Authorize root connections to the LXC:

        mkdir /var/lib/lxc/lptests/rootfs/root/.ssh
        cp ~buildbot/.ssh/authorized_keys /var/lib/lxc/lptests/rootfs/root/.ssh/
  12. Append to /var/lib/lxc/lptests/fstab the line

        none dev/shm tmpfs defaults 0 0


    This step must be removed when lucid is no longer used as the LXC OS.

  13. Start the lxc: lxc-start -n lptests -d

  14. Wait for the LXC to start and accept connections.
  15. Install the three scripts needed by buildbot: lp-setup-lxc-build, lp-setup-lxc-cleanup, and lp-setup-lxc-test. They will go into /usr/local/bin.

  16. Create /etc/sudoers.d/launchpad-buildbot with the line

            buildbot ALL = (ALL) NOPASSWD: /usr/local/bin/lp-setup-lxc-cleanup, 
    /usr/local/bin/lp-setup-lxc-build, /usr/local/bin/lp-setup-lxc-test
  17. chmod 0440 /etc/sudoers.d/launchpad-buildbot

  18. Disable hardlink restriction (remove when 944386 is resolved):

        echo 0 > /proc/sys/kernel/yama/protected_nonaccess_hardlinks

It is possible to connect via ssh to the container using: ssh -i ~buildbot/.ssh/launchpad_lxc_id_rsa `lp-lxc-ip -n lptests -i eth0`

Inside the container as root

  1. Install lpsetup:

            apt-get install python-software-properties
            add-apt-repository ppa:yellow/ppa
            apt-get clean && apt-get update
            apt-get upgrade
            apt-get install lpsetup
  2. Now use lpsetup to finish the provisioning of the container:

        lp-setup init-target --yes -u buildbot -S  launchpad_lxc_id_rsa --skip-steps setup_home -f "Launchpad PQM" -E launchpad-pqm@canonical.com

Inside the container as buildbot

  1. lp-setup init-repo --yes --use-http --no-checkout -r ~/slaves/slave

  2. lp-setup update ~/slaves/slave/devel --use-http

Inside the container as root, again

  1. poweroff If that doesn’t work lxc-stop -n lptests in the host.

yellow/ParallelTestingSetupForDataCentre (last edited 2012-08-29 16:14:54 by frankban)