Blame SOURCES/PR116.patch

da591a
From 2a4952da6c5b9739a56201662d05841185420484 Mon Sep 17 00:00:00 2001
da591a
From: rpm-build <rpm-build>
da591a
Date: Sat, 30 May 2015 11:19:53 -0400
da591a
Subject: [PATCH] Rebase PR116
da591a
da591a
---
da591a
 Makefile-tests.am                    |   4 ++
da591a
 src/libostree/ostree-sysroot.c       |  47 ++++++++++-----
da591a
 tests/admin-test.sh                  |  24 ++++++--
da591a
 tests/grub2-entries-crosscheck.py    | 105 ++++++++++++++++++++++++++++++++++
da591a
 tests/syslinux-entries-crosscheck.py | 107 +++++++++++++++++++++++++++++++++++
da591a
 5 files changed, 269 insertions(+), 18 deletions(-)
da591a
 create mode 100644 tests/grub2-entries-crosscheck.py
da591a
 create mode 100644 tests/syslinux-entries-crosscheck.py
da591a
da591a
diff --git a/Makefile-tests.am b/Makefile-tests.am
da591a
index 46bf499..06db55b 100644
da591a
--- a/Makefile-tests.am
da591a
+++ b/Makefile-tests.am
da591a
@@ -72,6 +72,10 @@ insttest_DATA = tests/archive-test.sh \
da591a
 	tests/corrupt-repo-ref.js \
da591a
 	$(NULL)
da591a
 
da591a
+insttest_SCRIPTS += \
da591a
+	tests/syslinux-entries-crosscheck.py \
da591a
+	$(NULL)
da591a
+
da591a
 gpginsttestdir = $(pkglibexecdir)/installed-tests/gpghome
da591a
 gpginsttest_DATA = tests/gpghome/secring.gpg \
da591a
 	tests/gpghome/trustdb.gpg
da591a
diff --git a/src/libostree/ostree-sysroot.c b/src/libostree/ostree-sysroot.c
da591a
index 6255803..b15ddf5 100644
da591a
--- a/src/libostree/ostree-sysroot.c
da591a
+++ b/src/libostree/ostree-sysroot.c
da591a
@@ -355,6 +355,35 @@ _ostree_sysroot_read_current_subbootversion (OstreeSysroot *self,
da591a
   return ret;
da591a
 }
da591a
 
da591a
+static gint
da591a
+compare_boot_loader_configs (OstreeBootconfigParser     *a,
da591a
+                             OstreeBootconfigParser     *b)
da591a
+{
da591a
+  const char *a_version = ostree_bootconfig_parser_get (a, "version");
da591a
+  const char *b_version = ostree_bootconfig_parser_get (b, "version");
da591a
+
da591a
+  if (a_version && b_version)
da591a
+    {
da591a
+      int r = strverscmp (a_version, b_version);
da591a
+      /* Reverse */
da591a
+      return -r;
da591a
+    }
da591a
+  else if (a_version)
da591a
+    return -1;
da591a
+  else
da591a
+    return 1;
da591a
+}
da591a
+
da591a
+static int
da591a
+compare_loader_configs_for_sorting (gconstpointer  a_pp,
da591a
+                                    gconstpointer  b_pp)
da591a
+{
da591a
+  OstreeBootconfigParser *a = *((OstreeBootconfigParser**)a_pp);
da591a
+  OstreeBootconfigParser *b = *((OstreeBootconfigParser**)b_pp);
da591a
+
da591a
+  return compare_boot_loader_configs (a, b);
da591a
+}
da591a
+
da591a
 gboolean
da591a
 _ostree_sysroot_read_boot_loader_configs (OstreeSysroot *self,
da591a
                                           int            bootversion,
da591a
@@ -421,6 +450,9 @@ _ostree_sysroot_read_boot_loader_configs (OstreeSysroot *self,
da591a
         }
da591a
     }
da591a
 
da591a
+  /* Callers expect us to give them a sorted array */
da591a
+  g_ptr_array_sort (ret_loader_configs, compare_loader_configs_for_sorting);
da591a
+
da591a
  done:
da591a
   gs_transfer_out_value (out_loader_configs, &ret_loader_configs);
da591a
   ret = TRUE;
da591a
@@ -700,19 +732,8 @@ compare_deployments_by_boot_loader_version_reversed (gconstpointer     a_pp,
da591a
   OstreeDeployment *b = *((OstreeDeployment**)b_pp);
da591a
   OstreeBootconfigParser *a_bootconfig = ostree_deployment_get_bootconfig (a);
da591a
   OstreeBootconfigParser *b_bootconfig = ostree_deployment_get_bootconfig (b);
da591a
-  const char *a_version = ostree_bootconfig_parser_get (a_bootconfig, "version");
da591a
-  const char *b_version = ostree_bootconfig_parser_get (b_bootconfig, "version");
da591a
-  
da591a
-  if (a_version && b_version)
da591a
-    {
da591a
-      int r = strverscmp (a_version, b_version);
da591a
-      /* Reverse */
da591a
-      return -r;
da591a
-    }
da591a
-  else if (a_version)
da591a
-    return -1;
da591a
-  else
da591a
-    return 1;
da591a
+
da591a
+  return compare_boot_loader_configs (a_bootconfig, b_bootconfig);
da591a
 }
da591a
 
da591a
 /**
da591a
diff --git a/tests/admin-test.sh b/tests/admin-test.sh
da591a
index 4278e01..f7fbb92 100755
da591a
--- a/tests/admin-test.sh
da591a
+++ b/tests/admin-test.sh
da591a
@@ -20,17 +20,20 @@ set -e
da591a
 
da591a
 echo "1..10"
da591a
 
da591a
+function validate_bootloader() {
da591a
+    (cd ${test_tmpdir};
da591a
+     if test -f sysroot/boot/syslinux/syslinux.cfg; then
da591a
+	$(dirname $0)/syslinux-entries-crosscheck.py sysroot
da591a
+     fi)
da591a
+}
da591a
+
da591a
 ${CMD_PREFIX} ostree --repo=sysroot/ostree/repo pull-local --remote=testos testos-repo testos/buildmaster/x86_64-runtime
da591a
 rev=$(${CMD_PREFIX} ostree --repo=sysroot/ostree/repo rev-parse testos/buildmaster/x86_64-runtime)
da591a
 export rev
da591a
 # This initial deployment gets kicked off with some kernel arguments 
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot deploy --karg=root=LABEL=MOO --karg=quiet --os=testos testos:testos/buildmaster/x86_64-runtime
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot status | tee status.txt
da591a
-
da591a
-assert_file_has_content status.txt 'Version: 1.0.10'
da591a
-if test -f sysroot/boot/loader/syslinux.cfg; then
da591a
-    assert_file_has_content sysroot/boot/loader/syslinux.cfg 'TestOS 42 1.0.10'
da591a
-fi
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok deploy command"
da591a
 
da591a
@@ -66,6 +69,7 @@ assert_file_has_content sysroot/boot/loader/entries/ostree-testos-0.conf 'option
da591a
 assert_file_has_content sysroot/ostree/deploy/testos/deploy/${rev}.1/etc/os-release 'NAME=TestOS'
da591a
 assert_file_has_content sysroot/ostree/boot.0/testos/${bootcsum}/0/etc/os-release 'NAME=TestOS'
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot status
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok second deploy"
da591a
 
da591a
@@ -77,6 +81,7 @@ assert_not_has_dir sysroot/boot/loader.1
da591a
 assert_has_dir sysroot/ostree/boot.0.0
da591a
 assert_not_has_dir sysroot/ostree/boot.0.1
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot status
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok third deploy (swap)"
da591a
 
da591a
@@ -90,6 +95,7 @@ assert_has_file sysroot/boot/loader/entries/ostree-otheros-0.conf
da591a
 assert_file_has_content sysroot/ostree/deploy/testos/deploy/${rev}.1/etc/os-release 'NAME=TestOS'
da591a
 assert_file_has_content sysroot/ostree/deploy/otheros/deploy/${rev}.0/etc/os-release 'NAME=TestOS'
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot status
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok independent deploy"
da591a
 
da591a
@@ -101,6 +107,7 @@ assert_file_has_content sysroot/ostree/deploy/testos/deploy/${rev}.2/etc/os-rele
da591a
 assert_has_file sysroot/boot/loader/entries/ostree-testos-2.conf
da591a
 assert_file_has_content sysroot/ostree/deploy/testos/deploy/${rev}.3/etc/os-release 'NAME=TestOS'
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot status
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok fourth deploy (retain)"
da591a
 
da591a
@@ -116,6 +123,7 @@ assert_file_has_content sysroot/ostree/deploy/testos/deploy/${rev}.4/etc/os-rele
da591a
 assert_file_has_content sysroot/ostree/deploy/testos/deploy/${rev}.4/etc/a-new-config-file 'a new local config file'
da591a
 assert_not_has_file sysroot/ostree/deploy/testos/deploy/${rev}.4/etc/aconfigfile
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot status
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok deploy with modified /etc"
da591a
 
da591a
@@ -133,6 +141,7 @@ assert_file_has_content sysroot/ostree/deploy/testos/deploy/${newrev}.0/etc/new-
da591a
 # And persist /etc changes from before
da591a
 assert_not_has_file sysroot/ostree/deploy/testos/deploy/${rev}.3/etc/aconfigfile
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot status
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok upgrade bare"
da591a
 
da591a
@@ -145,6 +154,7 @@ newrev=$(${CMD_PREFIX} ostree --repo=sysroot/ostree/repo rev-parse testos/buildm
da591a
 assert_not_streq ${rev} ${newrev}
da591a
 assert_file_has_content sysroot/ostree/deploy/testos/deploy/${newrev}.0/etc/os-release 'NAME=TestOS'
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot status
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok upgrade"
da591a
 
da591a
@@ -155,6 +165,7 @@ assert_file_has_content "${originfile}" "bacon:testos/buildmaster/x86_64-runtime
da591a
 ${CMD_PREFIX} ostree --repo=sysroot/ostree/repo remote list -u > remotes.txt
da591a
 assert_file_has_content remotes.txt 'bacon.*http://tasty.com'
da591a
 cp saved-origin ${originfile}
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok set-origin"
da591a
 
da591a
@@ -167,6 +178,7 @@ assert_not_has_dir sysroot/ostree/deploy/testos/deploy/${rev}.0
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot undeploy 0
da591a
 assert_not_has_dir sysroot/ostree/deploy/testos/deploy/${newrev}.0
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot status
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok undeploy"
da591a
 
da591a
@@ -178,6 +190,7 @@ echo "ok deploy with unknown OS"
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot deploy --os=testos --karg-append=console=/dev/foo --karg-append=console=/dev/bar testos:testos/buildmaster/x86_64-runtime
da591a
 ${CMD_PREFIX} ostree admin --sysroot=sysroot deploy --os=testos testos:testos/buildmaster/x86_64-runtime
da591a
 assert_file_has_content sysroot/boot/loader/entries/ostree-testos-0.conf 'console=/dev/foo.*console=/dev/bar'
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok deploy with multiple kernel args"
da591a
 
da591a
@@ -187,5 +200,6 @@ ${CMD_PREFIX} ostree admin --sysroot=sysroot upgrade --os=testos
da591a
 newrev=$(${CMD_PREFIX} ostree --repo=sysroot/ostree/repo rev-parse testos/buildmaster/x86_64-runtime)
da591a
 assert_not_streq ${origrev} ${newrev}
da591a
 assert_file_has_content sysroot/boot/loader/entries/ostree-testos-0.conf 'console=/dev/foo.*console=/dev/bar'
da591a
+validate_bootloader
da591a
 
da591a
 echo "ok upgrade with multiple kernel args"
da591a
diff --git a/tests/grub2-entries-crosscheck.py b/tests/grub2-entries-crosscheck.py
da591a
new file mode 100644
da591a
index 0000000..d68394d
da591a
--- /dev/null
da591a
+++ b/tests/grub2-entries-crosscheck.py
da591a
@@ -0,0 +1,105 @@
da591a
+#!/usr/bin/python
da591a
+#
da591a
+# Copyright (C) 2015 Red Hat
da591a
+#
da591a
+# This library is free software; you can redistribute it and/or
da591a
+# modify it under the terms of the GNU Lesser General Public
da591a
+# License as published by the Free Software Foundation; either
da591a
+# version 2 of the License, or (at your option) any later version.
da591a
+#
da591a
+# This library is distributed in the hope that it will be useful,
da591a
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
da591a
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
da591a
+# Lesser General Public License for more details.
da591a
+#
da591a
+# You should have received a copy of the GNU Lesser General Public
da591a
+# License along with this library; if not, write to the
da591a
+# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
da591a
+# Boston, MA 02111-1307, USA.
da591a
+
da591a
+import os
da591a
+import sys
da591a
+
da591a
+if len(sys.argv) == 1:
da591a
+    loaderpath = '/boot/loader/entries'
da591a
+    grub2path = '/boot/grub2/grub.cfg'
da591a
+else:
da591a
+    loaderpath = sys.argv[1]
da591a
+    grub2path = sys.argv[2]
da591a
+
da591a
+def fatal(msg):
da591a
+    sys.stderr.write(msg)
da591a
+    sys.stderr.write('\n')
da591a
+    sys.exit(1)
da591a
+
da591a
+def compare_entries_descending(a, b):
da591a
+    return int(b['version']) - int(a['version'])
da591a
+
da591a
+def get_ostree_option(optionstring):
da591a
+    for o in optionstring.split():
da591a
+        if o.startswith('ostree='):
da591a
+            return o[8:]
da591a
+    raise ValueError('ostree= not found')
da591a
+            
da591a
+entries = []
da591a
+grub2_entries = []
da591a
+
da591a
+# Parse loader configs
da591a
+for fname in os.listdir(loaderpath):
da591a
+    path = os.path.join(loaderpath, fname)
da591a
+    with open(path) as f:
da591a
+        entry = {}
da591a
+        for line in f:
da591a
+            line = line.strip()
da591a
+            if (line == '' or line.startswith('#')):
da591a
+                continue
da591a
+            s = line.find(' ')
da591a
+            assert s > 0
da591a
+            k = line[0:s]
da591a
+            v = line[s+1:]
da591a
+            entry[k] = v
da591a
+        entries.append(entry)
da591a
+    entries.sort(compare_entries_descending)
da591a
+
da591a
+# Parse GRUB2 config
da591a
+with open(grub2path) as f:
da591a
+    in_ostree_config = False
da591a
+    grub2_entry = None
da591a
+    for line in f:
da591a
+        if line.startswith('### BEGIN /etc/grub.d/15_ostree ###'):
da591a
+            in_ostree_config = True
da591a
+        elif line.startswith('### END /etc/grub.d/15_ostree ###'): 
da591a
+            in_ostree_config = False
da591a
+            if grub2_entry is not None:
da591a
+                grub2_entries.append(grub2_entry)
da591a
+        elif in_ostree_config:
da591a
+            if line.startswith('menuentry '):
da591a
+                if grub2_entry is not None:
da591a
+                    grub2_entries.append(grub2_entry)
da591a
+                grub2_entry = {}
da591a
+            elif line.startswith('linux'):
da591a
+                parts = line.split()
da591a
+                grub2_entry['linux'] = parts[1]
da591a
+                grub2_entry['options'] = ' '.join(parts[2:])
da591a
+            elif line.startswith('initrd'):
da591a
+                grub2_entry['initrd'] = line.split()[1]
da591a
+
da591a
+if len(entries) != len(grub2_entries):
da591a
+    fatal("Found {0} loader entries, but {1} GRUB2 entries\n".format(len(entries), len(grub2_entries)))
da591a
+
da591a
+def assert_matches_key(a, b, key):
da591a
+    aval = a[key]
da591a
+    bval = b[key]
da591a
+    if aval != bval:
da591a
+        fatal("Mismatch on {0}: {1} != {2}".format(key, aval, bval))
da591a
+
da591a
+for i,(entry,grub2entry) in enumerate(zip(entries, grub2_entries)):
da591a
+    assert_matches_key(entry, grub2entry, 'linux')
da591a
+    assert_matches_key(entry, grub2entry, 'initrd')
da591a
+    entry_ostree = get_ostree_option(entry['options'])
da591a
+    grub2_ostree = get_ostree_option(grub2entry['options'])
da591a
+    if entry_ostree != grub2_ostree:
da591a
+        fatal("Mismatch on ostree option: {0} != {1}".format(entry_ostree, grub2_ostree))
da591a
+
da591a
+sys.stdout.write('GRUB2 configuration validated\n')
da591a
+sys.exit(0)
da591a
diff --git a/tests/syslinux-entries-crosscheck.py b/tests/syslinux-entries-crosscheck.py
da591a
new file mode 100644
da591a
index 0000000..8b58ed4
da591a
--- /dev/null
da591a
+++ b/tests/syslinux-entries-crosscheck.py
da591a
@@ -0,0 +1,107 @@
da591a
+#!/usr/bin/python
da591a
+#
da591a
+# Copyright (C) 2015 Red Hat
da591a
+#
da591a
+# This library is free software; you can redistribute it and/or
da591a
+# modify it under the terms of the GNU Lesser General Public
da591a
+# License as published by the Free Software Foundation; either
da591a
+# version 2 of the License, or (at your option) any later version.
da591a
+#
da591a
+# This library is distributed in the hope that it will be useful,
da591a
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
da591a
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
da591a
+# Lesser General Public License for more details.
da591a
+#
da591a
+# You should have received a copy of the GNU Lesser General Public
da591a
+# License along with this library; if not, write to the
da591a
+# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
da591a
+# Boston, MA 02111-1307, USA.
da591a
+
da591a
+import os
da591a
+import sys
da591a
+
da591a
+if len(sys.argv) == 1:
da591a
+    sysroot = ''
da591a
+else:
da591a
+    sysroot = sys.argv[1]
da591a
+
da591a
+loaderpath = sysroot + '/boot/loader/entries'
da591a
+syslinuxpath = sysroot + '/boot/syslinux/syslinux.cfg'
da591a
+
da591a
+def fatal(msg):
da591a
+    sys.stderr.write(msg)
da591a
+    sys.stderr.write('\n')
da591a
+    sys.exit(1)
da591a
+
da591a
+def compare_entries_descending(a, b):
da591a
+    return int(b['version']) - int(a['version'])
da591a
+
da591a
+def get_ostree_option(optionstring):
da591a
+    for o in optionstring.split():
da591a
+        if o.startswith('ostree='):
da591a
+            return o[8:]
da591a
+    raise ValueError('ostree= not found')
da591a
+            
da591a
+entries = []
da591a
+syslinux_entries = []
da591a
+
da591a
+# Parse loader configs
da591a
+for fname in os.listdir(loaderpath):
da591a
+    path = os.path.join(loaderpath, fname)
da591a
+    with open(path) as f:
da591a
+        entry = {}
da591a
+        for line in f:
da591a
+            line = line.strip()
da591a
+            if (line == '' or line.startswith('#')):
da591a
+                continue
da591a
+            s = line.find(' ')
da591a
+            assert s > 0
da591a
+            k = line[0:s]
da591a
+            v = line[s+1:]
da591a
+            entry[k] = v
da591a
+        entries.append(entry)
da591a
+    entries.sort(compare_entries_descending)
da591a
+
da591a
+# Parse SYSLINUX config
da591a
+with open(syslinuxpath) as f:
da591a
+    in_ostree_config = False
da591a
+    syslinux_entry = None
da591a
+    syslinux_default = None
da591a
+    for line in f:
da591a
+        line = line.strip()
da591a
+        if line.startswith('DEFAULT '):
da591a
+            if syslinux_entry is not None:
da591a
+                syslinux_default = line.split(' ', 1)[1]
da591a
+        elif line.startswith('LABEL '):
da591a
+            if syslinux_entry is not None:
da591a
+                syslinux_entries.append(syslinux_entry)
da591a
+            syslinux_entry = {}
da591a
+            syslinux_entry['title'] = line.split(' ', 1)[1]
da591a
+        elif line.startswith('KERNEL '):
da591a
+            syslinux_entry['linux'] = line.split(' ', 1)[1]
da591a
+        elif line.startswith('INITRD '):
da591a
+            syslinux_entry['initrd'] = line.split(' ', 1)[1]
da591a
+        elif line.startswith('APPEND '):
da591a
+            syslinux_entry['options'] = line.split(' ', 1)[1]
da591a
+    if syslinux_entry is not None:
da591a
+        syslinux_entries.append(syslinux_entry)
da591a
+
da591a
+if len(entries) != len(syslinux_entries):
da591a
+    fatal("Found {0} loader entries, but {1} SYSLINUX entries\n".format(len(entries), len(syslinux_entries)))
da591a
+
da591a
+def assert_matches_key(a, b, key):
da591a
+    aval = a[key]
da591a
+    bval = b[key]
da591a
+    if aval != bval:
da591a
+        fatal("Mismatch on {0}: {1} != {2}".format(key, aval, bval))
da591a
+
da591a
+for i,(entry,syslinuxentry) in enumerate(zip(entries, syslinux_entries)):
da591a
+    assert_matches_key(entry, syslinuxentry, 'linux')
da591a
+    assert_matches_key(entry, syslinuxentry, 'initrd')
da591a
+    entry_ostree = get_ostree_option(entry['options'])
da591a
+    syslinux_ostree = get_ostree_option(syslinuxentry['options'])
da591a
+    if entry_ostree != syslinux_ostree:
da591a
+        fatal("Mismatch on ostree option: {0} != {1}".format(entry_ostree, syslinux_ostree))
da591a
+
da591a
+sys.stdout.write('SYSLINUX configuration validated\n')
da591a
+sys.exit(0)
da591a
-- 
da591a
1.8.3.1
da591a