--- trunk/grubby/test.sh 2013/10/21 14:00:03 2254 +++ trunk/grubby/test.sh 2014/07/16 10:48:35 2695 @@ -158,7 +158,7 @@ # generate convenience functions for b in $(./grubby --help | \ - sed -n 's/^.*--\([^ ]*\) *configure \1 bootloader$/\1/p'); do + sed -n 's/^.*--\([^ ]*\) *configure \1 bootloader.*/\1/p'); do eval "${b}Test() { [[ \"$b\" == \$opt_bootloader ]] && oneTest --$b \"\$@\"; }" eval "${b}DisplayTest() { [[ \"$b\" == \$opt_bootloader ]] && oneDisplayTest --$b \"\$@\"; }" done @@ -316,12 +316,24 @@ --boot-filesystem=/ --copy-default --add-kernel=/boot/new-kernel \ --title="Some_Title" +testing="Extlinux default directive" +extlinuxTest extlinux.1 default/extlinux1.1 --boot-filesystem=/boot --add-kernel /boot/new-kernel --title Some_Title +extlinuxTest extlinux.1 default/extlinux1.2 --boot-filesystem=/boot --add-kernel /boot/new-kernel --title Some_Title --make-default +extlinuxTest extlinux.3 default/extlinux3.1 --boot-filesystem=/boot --set-default=/boot/vmlinuz-3.12.0-2.fc21.i686 +extlinuxTest extlinux.3 default/extlinux3.2 --boot-filesystem=/boot --set-default=/boot/vmlinuz-3.12.0-2.fc21.i686+PAE + testing="GRUB new kernel argument handling" grubTest grub.1 args/g1.1 --boot-filesystem=/boot \ --add-kernel=/boot/foo --title=some_title --args="1234" --copy-default grubTest grub.1 args/g1.2 --boot-filesystem=/boot \ --add-kernel=/boot/foo --title=some_title --args="1234" +testing="Extlinux new kernel argument handling" +extlinuxTest extlinux.1 args/extlinux1.1 --boot-filesystem=/boot \ + --add-kernel=/boot/foo --title=some_title --args="1234" --copy-default +extlinuxTest extlinux.1 args/extlinux1.2 --boot-filesystem=/boot \ + --add-kernel=/boot/foo --title=some_title --args="1234" + testing="GRUB remove kernel" grubTest grub.7 remove/g7.1 --boot-filesystem=/ \ --remove-kernel=/boot/vmlinuz-2.4.7-2.5 @@ -339,6 +351,12 @@ ziplTest zipl.1 remove/z1.1 --remove-kernel=/boot/vmlinuz-2.4.9-38 ziplTest zipl.1 remove/z1.2 --remove-kernel=DEFAULT +testing="Extlinux remove kernel" +extlinuxTest extlinux.4 remove/extlinux4.1 --boot-filesystem=/ \ + --remove-kernel=/boot/vmlinuz-3.11.7-301.fc20.i686 +extlinuxTest extlinux.3 remove/extlinux3.1 --boot-filesystem=/ \ + --remove-kernel=DEFAULT + testing="GRUB update kernel argument handling" grubTest grub.1 updargs/g1.1 --update-kernel=DEFAULT --args="root=/dev/hda1" grubTest grub.1 updargs/g1.2 --update-kernel=DEFAULT \ @@ -355,8 +373,6 @@ --remove-args="hdd root ro" grubTest grub.7 updargs/g7.2 --boot-filesystem=/ \ --update-kernel=ALL --args "hde=ide-scsi" -grubTest grub.7 updargs/g7.2 --boot-filesystem=/ \ - --update-kernel=ALL --args "hde=ide-scsi" grubTest grub.7 updargs/g7.3 --boot-filesystem=/ \ --update-kernel=DEFAULT --args "hde=ide-scsi" grubTest grub.7 updargs/g7.4 --boot-filesystem=/ \ @@ -391,6 +407,30 @@ liloTest lilo.3 updargs/l3.2 --update-kernel=ALL \ --remove-args="single" --args "root=/dev/hda2" +testing="Extlinux update kernel argument handling" +extlinuxTest extlinux.1 updargs/extlinux1.1 --update-kernel=DEFAULT --args="root=/dev/hda1" +extlinuxTest extlinux.1 updargs/extlinux1.2 --update-kernel=DEFAULT \ + --args="root=/dev/hda1 hda=ide-scsi root=/dev/hda2" +extlinuxTest extlinux.3 updargs/extlinux3.1 --update-kernel=DEFAULT --args "hdd=notide-scsi" +extlinuxTest extlinux.3 updargs/extlinux3.2 --update-kernel=DEFAULT \ + --args "hdd=notide-scsi root=/dev/hdd1" +extlinuxTest extlinux.3 updargs/extlinux3.2 --update-kernel=DEFAULT \ + --args "root=/dev/hdd1 hdd=notide-scsi" +extlinuxTest extlinux.3 updargs/extlinux3.4 --update-kernel=ALL --remove-args="hdd" +extlinuxTest extlinux.3 updargs/extlinux3.4 --update-kernel=ALL --remove-args="hdd=ide-scsi" +extlinuxTest extlinux.3 updargs/extlinux3.4 --update-kernel=ALL --remove-args="hdd=foobar" +extlinuxTest extlinux.3 updargs/extlinux3.7 --update-kernel=ALL \ + --remove-args="hdd root ro" +extlinuxTest extlinux.4 updargs/extlinux4.2 --boot-filesystem=/ \ + --update-kernel=ALL --args "hde=ide-scsi" +extlinuxTest extlinux.4 updargs/extlinux4.3 --boot-filesystem=/ \ + --update-kernel=DEFAULT --args "hde=ide-scsi" +extlinuxTest extlinux.4 updargs/extlinux4.4 --boot-filesystem=/ \ + --update-kernel=/vmlinuz-3.12.0-2.fc21.i686 \ + --args "ro root=LABEL=/ console=tty0 console=ttyS1,9600n81 single" +extlinuxTest extlinux.4 updargs/extlinux4.5 --boot-filesystem=/ \ + --update-kernel=ALL --args "root=/dev/hda2" + testing="LILO add kernel" liloTest lilo.4 add/l4.1 --add-kernel=/boot/new-kernel.img --title="title" \ --copy-default --boot-filesystem=/boot @@ -443,9 +483,20 @@ grub2Test grub2.1 add/g2-1.1 --add-kernel=/boot/new-kernel.img \ --title='title' --initrd=/boot/new-initrd --boot-filesystem=/boot/ \ --copy-default - grub2Test grub2.1 add/g2-1.6 --add-kernel=/boot/new-kernel.img \ - --title='title' --initrd=/boot/new-initrd --boot-filesystem=/boot/ \ - --copy-default --efi + case $ARCH in + aarch64) + grub2Test grub2.1 add/g2-1.1 --add-kernel=/boot/new-kernel.img \ + --title='title' \ + --initrd=/boot/new-initrd --boot-filesystem=/boot/ \ + --copy-default --efi + ;; + *) + grub2Test grub2.1 add/g2-1.6 --add-kernel=/boot/new-kernel.img \ + --title='title' \ + --initrd=/boot/new-initrd --boot-filesystem=/boot/ \ + --copy-default --efi + ;; + esac grub2Test grub2.6 add/g2-1.7 --add-kernel=/boot/new-kernel.img \ --title='title' --initrd=/boot/new-initrd --boot-filesystem=/boot/ \ --copy-default --efi @@ -460,6 +511,18 @@ grub2Test grub2.5 add/g2-1.5 --add-kernel=/boot/new-kernel.img \ --title='title' --initrd=/boot/new-initrd --boot-filesystem=/boot/ \ --copy-default + grub2Test grub2.12 add/g2-1.12 \ + --add-kernel=/boot/vmlinuz-2.6.38.8-32.fc15.x86_64 \ + --title='Linux, with Fedora 2.6.38.8-32.fc15.x86_64' \ + --devtree='/boot/dtb-2.6.38.8-32.fc15.x86_64/foobarbaz.dtb' \ + --initrd=/boot/initramfs-2.6.38.8-32.fc15.x86_64.img \ + --boot-filesystem=/boot/ --copy-default --efi + grub2Test grub2.13 add/g2-1.13 \ + --add-kernel=/boot/vmlinuz-2.6.38.8-32.fc15.x86_64 \ + --title='Linux, with Fedora 2.6.38.8-32.fc15.x86_64' \ + --devtree='/boot/dtb-2.6.38.8-32.fc15.x86_64/foobarbaz.dtb' \ + --initrd=/boot/initramfs-2.6.38.8-32.fc15.x86_64.img \ + --boot-filesystem=/boot/ --copy-default --efi testing="GRUB2 add initrd" grub2Test grub2.2 add/g2-1.4 --update-kernel=/boot/new-kernel.img \ @@ -506,6 +569,19 @@ "grub2-editenv test/grub2-support_files/env_temp list" \ "saved_entry=Linux, with Fedora 2.6.38.8-32.fc15.x86_64" + testing="GRUB2 add kernel with default=saved_entry and a terrible title" + grub2Test grub2.7 add/g2-1.9 --env grubenv.1 \ + --add-kernel=/boot/new-kernel.img \ + --title='Fedora (3.10.3-300.fc19.x86_64) 19 (Schrödinger’s Cat)' \ + --initrd=/boot/new-initrd --boot-filesystem=/boot/ \ + --copy-default + + testing="GRUB2 set default with default=saved_entry and a terrible name" + grub2Test grub2.9 add/g2-1.9 --env grubenv.1 --set-default-index=0 + commandTest "saved_default output" \ + "grub2-editenv test/grub2-support_files/env_temp list" \ + 'saved_entry=Fedora (3.10.3-300.fc19.x86_64) 19 (Schrödinger’s Cat)' + testing="GRUB2 set default with default=saved_entry" grub2Test grub2.8 add/g2-1.8 --env grubenv.1 --set-default-index=0 commandTest "saved_default output" \ @@ -520,6 +596,25 @@ testing="GRUB2 --default-title with default=saved_entry" grub2DisplayTest grub2.8 defaulttitle/g2.1 --env grubenv.1 --default-title + + testing="GRUB2 --default-index with default=saved_entry and empty grubenv" + grub2DisplayTest grub2.8 defaultindex/0 --env grubenv.0 --default-index + + testlinux16=n + case $ARCH in + ia32|x86_64) testlinux16=y ;; + esac + + if [ "$testlinux16" == "y" ]; then + testing="GRUB2 add kernel with linux16" + grub2Test grub2.10 add/g2-1.10 --add-kernel=/boot/new-kernel.img \ + --title='title' --initrd=/boot/new-initrd --boot-filesystem=/boot/ \ + --copy-default + + testing="GRUB2 add initrd with linux16" + grub2Test grub2.11 add/g2-1.11 --update-kernel=/boot/new-kernel.img \ + --initrd=/boot/new-initrd --boot-filesystem=/boot/ + fi fi testing="YABOOT add kernel" @@ -534,6 +629,20 @@ ziplTest zipl.1 add/z1.1 --add-kernel=/boot/new-kernel.img --title test ziplTest zipl.1 add/z1.2 --add-kernel=/boot/new-kernel.img --title test --copy-default +testing="Extlinux add kernel" +extlinuxTest extlinux.1 add/extlinux1.1 --add-kernel=/boot/new-kernel.img --title='title' \ + --initrd=/boot/new-initrd --boot-filesystem=/ +extlinuxTest extlinux.1 add/extlinux1.2 --add-kernel=/boot/new-kernel.img --title='title' \ + --initrd=/boot/new-initrd --boot-filesystem=/boot +extlinuxTest extlinux.1 add/extlinux1.3 --add-kernel=/boot/new-kernel.img --title='title' \ + --initrd=/boot/new-initrd --boot-filesystem=/ --copy-default +extlinuxTest extlinux.1 add/extlinux1.4 --add-kernel=/boot/new-kernel.img --title='title' \ + --initrd=/boot/new-initrd --boot-filesystem=/boot --copy-default +extlinuxTest extlinux.2 add/extlinux2.1 --add-kernel=/boot/vmlinuz-3.12.0-2.fc21.i686 \ + --initrd=/boot/initrd-3.12.0-2.fc21.i686-new.img --boot-filesystem=/boot --copy-default \ + --title="Fedora (3.12.0-2.fc21.i686) 20 (Heisenbug)" \ + --remove-kernel="TITLE=Fedora (3.12.0-2.fc21.i686) 20 (Heisenbug)" + testing="LILO long titles" liloTest lilo.1 longtitle/l1.1 --add-kernel=/boot/new-kernel.img \ --title="linux-longtitle" --copy-default --boot-filesystem=/boot