[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH OSSTEST v4 12/25] distros: support PV guest install from Debian netinst media.
The netinst media are iso images containing a base Debian install and some (image size dependent) additional tasks. On x86 the "multiarch" iso flavour contains a Xen capable kernel for both i386 and amd64 so use that. This adds support for two classes of ISO, the CD sized ones which are built nightly and the DVD sized ones which are built weekly. The images are downloaded using jigdo which sources the majority of the data from a local Debian mirror, for this reason I have not worried about the fact that the i386 and amd64 tests are downloading the same thing (adding a specific download job would require finding up to 4GB of scratch space for each flight). The ISOs booted using pygrub which can extract the kernel and initrd from a ISO image. The resulting guests are also booted with pygrub since the pv-grub-menu package is not available on the ISO images and we have pvgrub coverage from the netboot tests. Signed-off-by: Ian Campbell <ian.campbell@xxxxxxxxxx> --- v4: Support http_proxy in jigdo download v3: - Indent jigdo-lite script line to improve readability - Wrap bootloader_args - Fetch URL on target, to get a timeout. Use wget since that is arranged to be present. - include bootloader in test name. --- Osstest/Debian.pm | 7 ++++-- make-distros-flight | 23 ++++++++++++++++++ ts-debian-di-install | 67 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 95 insertions(+), 2 deletions(-) diff --git a/Osstest/Debian.pm b/Osstest/Debian.pm index b37540e..831290c 100644 --- a/Osstest/Debian.pm +++ b/Osstest/Debian.pm @@ -616,8 +616,6 @@ sub preseed_base ($$$;@) { $xopts{ExtraPreseed} ||= ''; my $preseed = <<"END"; -d-i mirror/suite string $suite - d-i debian-installer/locale string en_GB d-i console-keymaps-at/keymap select gb d-i keyboard-configuration/xkb-keymap string en_GB @@ -689,6 +687,11 @@ END d-i clock-setup/ntp-server string $ntpserver END + # For CDROM the suite is part of the image + $preseed .= <<END unless $xopts{CDROM}; +d-i mirror/suite string $suite +END + # deb http://ftp.debian.org/debian/ wheezy-backports main $preseed .= <<END if $extra_packages =~ m#\b/$suite-backports\b#; d-i apt-setup/local0/repository string \\ diff --git a/make-distros-flight b/make-distros-flight index 97df89a..e3ec8f7 100755 --- a/make-distros-flight +++ b/make-distros-flight @@ -85,6 +85,20 @@ test_do_one_netboot () { all_hostflags=$most_hostflags } +test_do_one_netinst () { + # Always pygrub since no pv-grub-menu on CD + job_create_test \ + test-$xenarch$kern-$dom0arch-$domU-$cd-netinst-pygrub \ + test-debian-di xl $xenarch $dom0arch \ + kernbuildjob=${bfi}build-$dom0arch-$kernbuild \ + debian_arch=$domU \ + debian_cd=$cd \ + debian_method=netinst \ + debian_bootloader=pygrub \ + all_hostflags=$most_hostflags + +} + test_matrix_do_one () { case ${xenarch} in amd64) domUarches="amd64 i386";; @@ -103,6 +117,15 @@ test_matrix_do_one () { done + for cd in current weekly ; do + case ${domU}_${dist} in + armhf_*) continue;; # No iso targets for armhf + *) ;; + esac + + test_do_one_netinst + + done done } diff --git a/ts-debian-di-install b/ts-debian-di-install index 73cb43d..62e9bb5 100755 --- a/ts-debian-di-install +++ b/ts-debian-di-install @@ -46,6 +46,63 @@ sub prep () { target_cmd_root($ho, "umount $gho->{Lvdev} ||:"); } +sub setup_netinst($$$) +{ + my ($didir, $arch, $cd) = @_; + my %arch_props = ( + amd64 => { PathArch => "multi-arch", FileArch => "amd64-i386", IsoPath => "/install.amd/xen" }, + i386 => { PathArch => "multi-arch", FileArch => "amd64-i386", IsoPath => "/install.386/xen" }, + armhf => { PathArch => "armhf", FileArch => "armhf", IsoPath => "/install.armhf" } + ); + my $props = $arch_props{$arch} or die "Unknown arch $arch"; + + target_install_packages($ho, qw(jigdo-file)); + + my $baseurl = $cd eq "current" ? + "http://cdimage.debian.org/debian-cd/current/$props->{PathArch}/jigdo-cd" : + "http://cdimage.debian.org/cdimage/weekly-builds/$props->{PathArch}/jigdo-cd"; + + my $filebase; + + # Use the MD5SUMs file as an index + logm("Fetch index from $baseurl/MD5SUMS"); + my $idx = target_cmd_output_root($ho, "wget --quiet -O - $baseurl/MD5SUMS"); + foreach (split /\n/, $idx) { + m/^[0-9a-f]{32} (debian-.*-$props->{FileArch}-netinst)\.iso$/ or next; + $filebase = $1; + last; + } + + die unless $filebase; + + logm("Downloading $baseurl/$filebase.jigdo"); + my $netinst_jigdo = "$baseurl/$filebase.jigdo"; + # Jigdo uses wget internally, and so obeys $http_proxy. This seems + # simpler than the advice at + # https://www.debian.org/CD/jigdo-cd/#faq which is to edit + # ~/.jigdo-lite and change the wgetOpts setting. + my $useproxy = $c{DebianMirrorProxy} // $c{HttpProxy}; + my $cmd = ''; + $cmd .= <<END if $useproxy; + export http_proxy=$useproxy +END + $cmd .= <<END; + cd $didir && jigdo-lite --noask $netinst_jigdo +END + # Jigdo seems to use /etc/apt/sources.list or something, so this + # just works using the already configured mirror without + # additional configuration, which is good because there doesn't + # seem to be any support for such things, at least in Squeeze. + target_cmd_root($ho, $cmd, 3600); + store_runvar("$gho->{Guest}_netinst_jigdo", $netinst_jigdo); + + return (<<END, "\"file:$didir/$filebase.iso,xvdd:cdrom,r\","); +bootloader = "pygrub" +bootloader_args = ["--kernel=$props->{IsoPath}/vmlinuz", + "--ramdisk=$props->{IsoPath}/initrd.gz"] +END +} + sub setup_netboot($$$) { my ($didir, $arch, $suite) = @_; @@ -115,6 +172,16 @@ END $extra_disk = ""; } + elsif ($method eq "netinst" ) + { + my $cd = $r{"$gho->{Guest}_cd"}; + + logm("$method $cd/$arch"); + + ($method_cfg,$extra_disk) = setup_netinst($tmpdir, $arch, $cd); + + $ps_url = preseed_create_guest($gho, '', CDROM=>1); + } else { die "$method"; -- 2.1.4 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |