Blame SOURCES/0004-Add-tests-for-btrfs-support.patch

9067cc
From e319f73ca691b9cc138def3a9c19f1cb6e581475 Mon Sep 17 00:00:00 2001
9067cc
From: Gene Czarcinski <gczarcinski@gmail.com>
9067cc
Date: Mon, 9 Jun 2014 21:11:37 -0400
9067cc
Subject: [PATCH 4/8] Add tests for btrfs support
9067cc
9067cc
The tests performed are:
9067cc
- add kernel with /boot on btrfs subvol (20)
9067cc
- update kernel/add initrd with /boot on btrfs subvol (21)
9067cc
- add kernel with rootfs on btrfs subvol and /boot a directory (22)
9067cc
- update kernel/add initrd with rootfs on btrfs subvol and
9067cc
  /boot a directory (23)
9067cc
- add kernel and initrd with /boot on btrfs subvol (24)
9067cc
- add kernel and initrd with rootfs on btrfs subvol and /boot
9067cc
  a directory (25)
9067cc
---
9067cc
 test.sh                               |  40 +++++++
9067cc
 test/grub2-support_files/g2.20-mounts |   2 +
9067cc
 test/grub2-support_files/g2.21-mounts |   1 +
9067cc
 test/grub2-support_files/g2.22-mounts |   1 +
9067cc
 test/grub2-support_files/g2.23-mounts |   1 +
9067cc
 test/grub2-support_files/g2.24-mounts |   1 +
9067cc
 test/grub2-support_files/g2.25-mounts |   1 +
9067cc
 test/grub2.20                         | 126 ++++++++++++++++++++++
9067cc
 test/grub2.21                         | 140 +++++++++++++++++++++++++
9067cc
 test/grub2.22                         | 128 +++++++++++++++++++++++
9067cc
 test/grub2.23                         | 143 +++++++++++++++++++++++++
9067cc
 test/grub2.24                         | 126 ++++++++++++++++++++++
9067cc
 test/grub2.25                         | 128 +++++++++++++++++++++++
9067cc
 test/results/add/g2-1.20              | 140 +++++++++++++++++++++++++
9067cc
 test/results/add/g2-1.21              | 141 +++++++++++++++++++++++++
9067cc
 test/results/add/g2-1.22              | 143 +++++++++++++++++++++++++
9067cc
 test/results/add/g2-1.23              | 144 ++++++++++++++++++++++++++
9067cc
 test/results/add/g2-1.24              | 141 +++++++++++++++++++++++++
9067cc
 test/results/add/g2-1.25              | 144 ++++++++++++++++++++++++++
9067cc
 19 files changed, 1691 insertions(+)
9067cc
 create mode 100644 test/grub2-support_files/g2.20-mounts
9067cc
 create mode 120000 test/grub2-support_files/g2.21-mounts
9067cc
 create mode 100644 test/grub2-support_files/g2.22-mounts
9067cc
 create mode 120000 test/grub2-support_files/g2.23-mounts
9067cc
 create mode 120000 test/grub2-support_files/g2.24-mounts
9067cc
 create mode 120000 test/grub2-support_files/g2.25-mounts
9067cc
 create mode 100644 test/grub2.20
9067cc
 create mode 100644 test/grub2.21
9067cc
 create mode 100644 test/grub2.22
9067cc
 create mode 100644 test/grub2.23
9067cc
 create mode 100644 test/grub2.24
9067cc
 create mode 100644 test/grub2.25
9067cc
 create mode 100644 test/results/add/g2-1.20
9067cc
 create mode 100644 test/results/add/g2-1.21
9067cc
 create mode 100644 test/results/add/g2-1.22
9067cc
 create mode 100644 test/results/add/g2-1.23
9067cc
 create mode 100644 test/results/add/g2-1.24
9067cc
 create mode 100644 test/results/add/g2-1.25
9067cc
9067cc
diff --git a/test.sh b/test.sh
9067cc
index 6379698c6de..c35bfca1c89 100755
9067cc
--- a/test.sh
9067cc
+++ b/test.sh
9067cc
@@ -629,6 +629,46 @@ if [ "$testgrub2" == "y" ]; then
9067cc
             --initrd /boot/initramfs-0-rescue-5a94251776a14678911d4ae0949500f5.img \
9067cc
             --copy-default --title "Fedora 21 Rescue" --args=root=/fooooo \
9067cc
             --remove-kernel=wtf --boot-filesystem=/boot/
9067cc
+
9067cc
+        testing="GRUB2 add kernel with boot on btrfs subvol"
9067cc
+        grub2Test grub2.20 add/g2-1.20 --add-kernel=/boot/new-kernel.img \
9067cc
+            --title='title' \
9067cc
+            --boot-filesystem=/boot/ \
9067cc
+            --copy-default \
9067cc
+            --mounts='test/grub2-support_files/g2.20-mounts'
9067cc
+
9067cc
+        testing="GRUB2 add initrd with boot on btrfs subvol"
9067cc
+        grub2Test grub2.21 add/g2-1.21 --update-kernel=/boot/new-kernel.img \
9067cc
+            --initrd=/boot/new-initrd --boot-filesystem=/boot/ \
9067cc
+            --mounts='test/grub2-support_files/g2.21-mounts'
9067cc
+
9067cc
+        testing="GRUB2 add kernel with rootfs on btrfs subvol and boot directory"
9067cc
+        grub2Test grub2.22 add/g2-1.22 --add-kernel=/boot/new-kernel.img \
9067cc
+            --title='title' \
9067cc
+            --boot-filesystem= \
9067cc
+            --copy-default \
9067cc
+            --mounts='test/grub2-support_files/g2.22-mounts'
9067cc
+
9067cc
+        testing="GRUB2 add initrd with rootfs on btrfs subvol and boot directory"
9067cc
+        grub2Test grub2.23 add/g2-1.23 --update-kernel=/boot/new-kernel.img \
9067cc
+            --initrd=/boot/new-initrd --boot-filesystem= \
9067cc
+            --mounts='test/grub2-support_files/g2.23-mounts'
9067cc
+
9067cc
+        testing="GRUB2 add kernel and initrd with boot on btrfs subvol"
9067cc
+        grub2Test grub2.24 add/g2-1.24 --add-kernel=/boot/new-kernel.img \
9067cc
+            --title='title' \
9067cc
+            --initrd=/boot/new-initrd \
9067cc
+            --boot-filesystem=/boot/ \
9067cc
+            --copy-default \
9067cc
+            --mounts='test/grub2-support_files/g2.24-mounts'
9067cc
+
9067cc
+        testing="GRUB2 add kernel and initrd with rootfs on btrfs subvol and boot directory"
9067cc
+        grub2Test grub2.25 add/g2-1.25 --add-kernel=/boot/new-kernel.img \
9067cc
+            --title='title' \
9067cc
+            --initrd=/boot/new-initrd \
9067cc
+            --boot-filesystem= \
9067cc
+            --copy-default \
9067cc
+            --mounts='test/grub2-support_files/g2.25-mounts'
9067cc
     fi
9067cc
 fi
9067cc
 
9067cc
diff --git a/test/grub2-support_files/g2.20-mounts b/test/grub2-support_files/g2.20-mounts
9067cc
new file mode 100644
9067cc
index 00000000000..00bdb48e4ab
9067cc
--- /dev/null
9067cc
+++ b/test/grub2-support_files/g2.20-mounts
9067cc
@@ -0,0 +1,2 @@
9067cc
+/dev/sda	/	btrfs	subvol=/root6,defaults	0 0
9067cc
+/dev/sda	/boot	btrfs	subvol=/boot6,defaults	0 0
9067cc
diff --git a/test/grub2-support_files/g2.21-mounts b/test/grub2-support_files/g2.21-mounts
9067cc
new file mode 120000
9067cc
index 00000000000..42ef3fd4272
9067cc
--- /dev/null
9067cc
+++ b/test/grub2-support_files/g2.21-mounts
9067cc
@@ -0,0 +1 @@
9067cc
+g2.20-mounts
9067cc
\ No newline at end of file
9067cc
diff --git a/test/grub2-support_files/g2.22-mounts b/test/grub2-support_files/g2.22-mounts
9067cc
new file mode 100644
9067cc
index 00000000000..5b664e72519
9067cc
--- /dev/null
9067cc
+++ b/test/grub2-support_files/g2.22-mounts
9067cc
@@ -0,0 +1 @@
9067cc
+/dev/sda	/	btrfs	defaults,subvol=/root4,ro	0 0
9067cc
diff --git a/test/grub2-support_files/g2.23-mounts b/test/grub2-support_files/g2.23-mounts
9067cc
new file mode 120000
9067cc
index 00000000000..74f036fc4a3
9067cc
--- /dev/null
9067cc
+++ b/test/grub2-support_files/g2.23-mounts
9067cc
@@ -0,0 +1 @@
9067cc
+g2.22-mounts
9067cc
\ No newline at end of file
9067cc
diff --git a/test/grub2-support_files/g2.24-mounts b/test/grub2-support_files/g2.24-mounts
9067cc
new file mode 120000
9067cc
index 00000000000..42ef3fd4272
9067cc
--- /dev/null
9067cc
+++ b/test/grub2-support_files/g2.24-mounts
9067cc
@@ -0,0 +1 @@
9067cc
+g2.20-mounts
9067cc
\ No newline at end of file
9067cc
diff --git a/test/grub2-support_files/g2.25-mounts b/test/grub2-support_files/g2.25-mounts
9067cc
new file mode 120000
9067cc
index 00000000000..74f036fc4a3
9067cc
--- /dev/null
9067cc
+++ b/test/grub2-support_files/g2.25-mounts
9067cc
@@ -0,0 +1 @@
9067cc
+g2.22-mounts
9067cc
\ No newline at end of file
9067cc
diff --git a/test/grub2.20 b/test/grub2.20
9067cc
new file mode 100644
9067cc
index 00000000000..23b75fa8d3c
9067cc
--- /dev/null
9067cc
+++ b/test/grub2.20
9067cc
@@ -0,0 +1,126 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-81378818f7a24478b496ebef90e1dd69' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-0-rescue-81378818f7a24478b496ebef90e1dd69 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-0-rescue-81378818f7a24478b496ebef90e1dd69.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+### END /etc/grub.d/30_os-prober ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/grub2.21 b/test/grub2.21
9067cc
new file mode 100644
9067cc
index 00000000000..579c2f6744a
9067cc
--- /dev/null
9067cc
+++ b/test/grub2.21
9067cc
@@ -0,0 +1,140 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'title' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/new-kernel.img root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-81378818f7a24478b496ebef90e1dd69' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-0-rescue-81378818f7a24478b496ebef90e1dd69 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-0-rescue-81378818f7a24478b496ebef90e1dd69.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+### END /etc/grub.d/30_os-prober ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/grub2.22 b/test/grub2.22
9067cc
new file mode 100644
9067cc
index 00000000000..9466bc35153
9067cc
--- /dev/null
9067cc
+++ b/test/grub2.22
9067cc
@@ -0,0 +1,128 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-20e7024f4e9c4b70b1042b91acd434c6' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-0-rescue-20e7024f4e9c4b70b1042b91acd434c6 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-0-rescue-20e7024f4e9c4b70b1042b91acd434c6.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/grub2.23 b/test/grub2.23
9067cc
new file mode 100644
9067cc
index 00000000000..5cb240fc1de
9067cc
--- /dev/null
9067cc
+++ b/test/grub2.23
9067cc
@@ -0,0 +1,143 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'title' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/new-kernel.img root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-20e7024f4e9c4b70b1042b91acd434c6' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-0-rescue-20e7024f4e9c4b70b1042b91acd434c6 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-0-rescue-20e7024f4e9c4b70b1042b91acd434c6.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/grub2.24 b/test/grub2.24
9067cc
new file mode 100644
9067cc
index 00000000000..23b75fa8d3c
9067cc
--- /dev/null
9067cc
+++ b/test/grub2.24
9067cc
@@ -0,0 +1,126 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-81378818f7a24478b496ebef90e1dd69' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-0-rescue-81378818f7a24478b496ebef90e1dd69 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-0-rescue-81378818f7a24478b496ebef90e1dd69.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+### END /etc/grub.d/30_os-prober ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/grub2.25 b/test/grub2.25
9067cc
new file mode 100644
9067cc
index 00000000000..9466bc35153
9067cc
--- /dev/null
9067cc
+++ b/test/grub2.25
9067cc
@@ -0,0 +1,128 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-20e7024f4e9c4b70b1042b91acd434c6' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-0-rescue-20e7024f4e9c4b70b1042b91acd434c6 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-0-rescue-20e7024f4e9c4b70b1042b91acd434c6.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/results/add/g2-1.20 b/test/results/add/g2-1.20
9067cc
new file mode 100644
9067cc
index 00000000000..579c2f6744a
9067cc
--- /dev/null
9067cc
+++ b/test/results/add/g2-1.20
9067cc
@@ -0,0 +1,140 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'title' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/new-kernel.img root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-81378818f7a24478b496ebef90e1dd69' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-0-rescue-81378818f7a24478b496ebef90e1dd69 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-0-rescue-81378818f7a24478b496ebef90e1dd69.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+### END /etc/grub.d/30_os-prober ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/results/add/g2-1.21 b/test/results/add/g2-1.21
9067cc
new file mode 100644
9067cc
index 00000000000..c0dded9724c
9067cc
--- /dev/null
9067cc
+++ b/test/results/add/g2-1.21
9067cc
@@ -0,0 +1,141 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'title' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/new-kernel.img root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/new-initrd
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-81378818f7a24478b496ebef90e1dd69' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-0-rescue-81378818f7a24478b496ebef90e1dd69 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-0-rescue-81378818f7a24478b496ebef90e1dd69.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+### END /etc/grub.d/30_os-prober ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/results/add/g2-1.22 b/test/results/add/g2-1.22
9067cc
new file mode 100644
9067cc
index 00000000000..5cb240fc1de
9067cc
--- /dev/null
9067cc
+++ b/test/results/add/g2-1.22
9067cc
@@ -0,0 +1,143 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'title' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/new-kernel.img root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-20e7024f4e9c4b70b1042b91acd434c6' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-0-rescue-20e7024f4e9c4b70b1042b91acd434c6 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-0-rescue-20e7024f4e9c4b70b1042b91acd434c6.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/results/add/g2-1.23 b/test/results/add/g2-1.23
9067cc
new file mode 100644
9067cc
index 00000000000..c3e87cf7897
9067cc
--- /dev/null
9067cc
+++ b/test/results/add/g2-1.23
9067cc
@@ -0,0 +1,144 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'title' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/new-kernel.img root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/new-initrd
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-20e7024f4e9c4b70b1042b91acd434c6' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-0-rescue-20e7024f4e9c4b70b1042b91acd434c6 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-0-rescue-20e7024f4e9c4b70b1042b91acd434c6.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/results/add/g2-1.24 b/test/results/add/g2-1.24
9067cc
new file mode 100644
9067cc
index 00000000000..c0dded9724c
9067cc
--- /dev/null
9067cc
+++ b/test/results/add/g2-1.24
9067cc
@@ -0,0 +1,141 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'title' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/new-kernel.img root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/new-initrd
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-81378818f7a24478b496ebef90e1dd69' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 1bab15a4-93ce-4373-8d7d-b77f907fd0c6
9067cc
+	fi
9067cc
+	linux16 /boot6/vmlinuz-0-rescue-81378818f7a24478b496ebef90e1dd69 root=UUID=1bab15a4-93ce-4373-8d7d-b77f907fd0c6 ro rootflags=subvol=root6 rhgb quiet
9067cc
+	initrd16 /boot6/initramfs-0-rescue-81378818f7a24478b496ebef90e1dd69.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+### END /etc/grub.d/30_os-prober ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
diff --git a/test/results/add/g2-1.25 b/test/results/add/g2-1.25
9067cc
new file mode 100644
9067cc
index 00000000000..c3e87cf7897
9067cc
--- /dev/null
9067cc
+++ b/test/results/add/g2-1.25
9067cc
@@ -0,0 +1,144 @@
9067cc
+#
9067cc
+# DO NOT EDIT THIS FILE
9067cc
+#
9067cc
+# It is automatically generated by grub2-mkconfig using templates
9067cc
+# from /etc/grub.d and settings from /etc/default/grub
9067cc
+#
9067cc
+
9067cc
+### BEGIN /etc/grub.d/00_header ###
9067cc
+set pager=1
9067cc
+
9067cc
+if [ -s $prefix/grubenv ]; then
9067cc
+  load_env
9067cc
+fi
9067cc
+if [ "${next_entry}" ] ; then
9067cc
+   set default="${next_entry}"
9067cc
+   set next_entry=
9067cc
+   save_env next_entry
9067cc
+   set boot_once=true
9067cc
+else
9067cc
+   set default="${saved_entry}"
9067cc
+fi
9067cc
+
9067cc
+if [ x"${feature_menuentry_id}" = xy ]; then
9067cc
+  menuentry_id_option="--id"
9067cc
+else
9067cc
+  menuentry_id_option=""
9067cc
+fi
9067cc
+
9067cc
+export menuentry_id_option
9067cc
+
9067cc
+if [ "${prev_saved_entry}" ]; then
9067cc
+  set saved_entry="${prev_saved_entry}"
9067cc
+  save_env saved_entry
9067cc
+  set prev_saved_entry=
9067cc
+  save_env prev_saved_entry
9067cc
+  set boot_once=true
9067cc
+fi
9067cc
+
9067cc
+function savedefault {
9067cc
+  if [ -z "${boot_once}" ]; then
9067cc
+    saved_entry="${chosen}"
9067cc
+    save_env saved_entry
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+function load_video {
9067cc
+  if [ x$feature_all_video_module = xy ]; then
9067cc
+    insmod all_video
9067cc
+  else
9067cc
+    insmod efi_gop
9067cc
+    insmod efi_uga
9067cc
+    insmod ieee1275_fb
9067cc
+    insmod vbe
9067cc
+    insmod vga
9067cc
+    insmod video_bochs
9067cc
+    insmod video_cirrus
9067cc
+  fi
9067cc
+}
9067cc
+
9067cc
+terminal_output console
9067cc
+if [ x$feature_timeout_style = xy ] ; then
9067cc
+  set timeout_style=menu
9067cc
+  set timeout=15
9067cc
+# Fallback normal timeout code in case the timeout_style feature is
9067cc
+# unavailable.
9067cc
+else
9067cc
+  set timeout=15
9067cc
+fi
9067cc
+### END /etc/grub.d/00_header ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/10_linux ###
9067cc
+menuentry 'title' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/new-kernel.img root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/new-initrd
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 3.15.0-0.rc7.git2.1.fc21.x86_64' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	set gfxpayload=keep
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-3.15.0-0.rc7.git2.1.fc21.x86_64 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-3.15.0-0.rc7.git2.1.fc21.x86_64.img
9067cc
+}
9067cc
+menuentry 'Fedora, with Linux 0-rescue-20e7024f4e9c4b70b1042b91acd434c6' --class gnu-linux --class gnu --class os {
9067cc
+	load_video
9067cc
+	insmod gzio
9067cc
+	insmod part_msdos
9067cc
+	insmod part_msdos
9067cc
+	insmod btrfs
9067cc
+	set root='hd0,msdos1'
9067cc
+	if [ x$feature_platform_search_hint = xy ]; then
9067cc
+	  search --no-floppy --fs-uuid --set=root --hint='hd0,msdos1'  --hint='hd1,msdos3'  54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	else
9067cc
+	  search --no-floppy --fs-uuid --set=root 54c6abc2-b1e7-4987-aa73-c79927be69eb
9067cc
+	fi
9067cc
+	linux16 /root4/boot/vmlinuz-0-rescue-20e7024f4e9c4b70b1042b91acd434c6 root=UUID=54c6abc2-b1e7-4987-aa73-c79927be69eb ro rootflags=subvol=root4 rhgb quiet
9067cc
+	initrd16 /root4/boot/initramfs-0-rescue-20e7024f4e9c4b70b1042b91acd434c6.img
9067cc
+}
9067cc
+
9067cc
+### END /etc/grub.d/10_linux ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### END /etc/grub.d/20_linux_xen ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/20_ppc_terminfo ###
9067cc
+### END /etc/grub.d/20_ppc_terminfo ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/30_os-prober ###
9067cc
+###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/40_custom ###
9067cc
+# This file provides an easy way to add custom menu entries.  Simply type the
9067cc
+# menu entries you want to add after this comment.  Be careful not to change
9067cc
+# the 'exec tail' line above.
9067cc
+### END /etc/grub.d/40_custom ###
9067cc
+
9067cc
+### BEGIN /etc/grub.d/41_custom ###
9067cc
+if [ -f  ${config_directory}/custom.cfg ]; then
9067cc
+  source ${config_directory}/custom.cfg
9067cc
+elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
9067cc
+  source $prefix/custom.cfg;
9067cc
+fi
9067cc
+### END /etc/grub.d/41_custom ###
9067cc
-- 
9067cc
2.17.1
9067cc