Blame SOURCES/0038-Add-some-test-cases-for-efivar-export-import.patch

d5c737
From 693dbef8d7d6287b438ad7e385b383f60df74a8c Mon Sep 17 00:00:00 2001
d5c737
From: Peter Jones <pjones@redhat.com>
d5c737
Date: Tue, 18 Jun 2019 13:21:45 -0400
d5c737
Subject: [PATCH 38/63] Add some test cases for efivar export/import
d5c737
d5c737
Signed-off-by: Peter Jones <pjones@redhat.com>
d5c737
---
d5c737
 Makefile              |   3 ++
d5c737
 tests/.gitignore      |   2 +
d5c737
 tests/Makefile        |  86 ++++++++++++++++++++++++++++++++++++++++++
d5c737
 tests/test.0.goal.var | Bin 0 -> 562 bytes
d5c737
 tests/test.1.goal.var | Bin 0 -> 574 bytes
d5c737
 tests/test.3.goal.var | Bin 0 -> 66 bytes
d5c737
 tests/test.4.goal.var | Bin 0 -> 365 bytes
d5c737
 7 files changed, 91 insertions(+)
d5c737
 create mode 100644 tests/.gitignore
d5c737
 create mode 100644 tests/Makefile
d5c737
 create mode 100644 tests/test.0.goal.var
d5c737
 create mode 100644 tests/test.1.goal.var
d5c737
 create mode 100644 tests/test.3.goal.var
d5c737
 create mode 100644 tests/test.4.goal.var
d5c737
d5c737
diff --git a/Makefile b/Makefile
d5c737
index 9c2620cb485..2d134ea9d6f 100644
d5c737
--- a/Makefile
d5c737
+++ b/Makefile
d5c737
@@ -51,6 +51,9 @@ clean :
d5c737
 	done
d5c737
 	@rm -vf efivar.spec vgcore.* core.*
d5c737
 
d5c737
+test : all
d5c737
+	@$(MAKE) -C tests
d5c737
+
d5c737
 test-archive: abicheck efivar.spec
d5c737
 	@rm -rf /tmp/efivar-$(GITTAG) /tmp/efivar-$(GITTAG)-tmp
d5c737
 	@mkdir -p /tmp/efivar-$(GITTAG)-tmp
d5c737
diff --git a/tests/.gitignore b/tests/.gitignore
d5c737
new file mode 100644
d5c737
index 00000000000..a0149cf75de
d5c737
--- /dev/null
d5c737
+++ b/tests/.gitignore
d5c737
@@ -0,0 +1,2 @@
d5c737
+!*.var
d5c737
+*.result.*
d5c737
diff --git a/tests/Makefile b/tests/Makefile
d5c737
new file mode 100644
d5c737
index 00000000000..5e0c604e355
d5c737
--- /dev/null
d5c737
+++ b/tests/Makefile
d5c737
@@ -0,0 +1,86 @@
d5c737
+#
d5c737
+# Makefile
d5c737
+# Peter Jones, 2019-06-18 11:10
d5c737
+#
d5c737
+
d5c737
+all: clean test0 test1 test2 test3 test4
d5c737
+
d5c737
+GRUB_PREFIX ?= grub2
d5c737
+TOPDIR ?= ..
d5c737
+EFIVAR ?= ../src/efivar
d5c737
+
d5c737
+clean:
d5c737
+	@rm -f *.result.env *.result.var
d5c737
+
d5c737
+test0:
d5c737
+	@echo testing export to DMPSTORE format
d5c737
+	@$(GRUB_PREFIX)-editenv test.0.result.env create
d5c737
+	@$(GRUB_PREFIX)-editenv test.0.result.env set debug=all,-scripting,-lexer
d5c737
+	@truncate -s 512 test.0.result.env
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -n {grub}-GRUB_ENV -f test.0.result.env -D -e test.0.result.var
d5c737
+	@cmp test.0.result.var test.0.goal.var
d5c737
+	@rm test.0.result.*
d5c737
+	@echo passed
d5c737
+
d5c737
+test1:
d5c737
+	@echo testing export to libefivar format
d5c737
+	@$(GRUB_PREFIX)-editenv test.1.result.env create
d5c737
+	@$(GRUB_PREFIX)-editenv test.1.result.env set debug=all,-scripting,-lexer
d5c737
+	@truncate -s 512 test.1.result.env
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -n {grub}-GRUB_ENV -f test.1.result.env -e test.1.result.var
d5c737
+	@cmp test.1.result.var test.1.goal.var
d5c737
+	@rm test.1.result.*
d5c737
+	@echo passed
d5c737
+
d5c737
+test2:
d5c737
+	@$(GRUB_PREFIX)-editenv test.2.result.env create
d5c737
+	@$(GRUB_PREFIX)-editenv test.2.result.env set debug=all,-scripting,-lexer
d5c737
+	@truncate -s 512 test.2.result.env
d5c737
+	@echo test importing from DMPSTORE and exporting to DMPSTORE and symbolic guid-name validation
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -n {grub}-GRUB_ENV -f test.2.result.env -D -e test.2.0.goal.var
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -i test.2.0.goal.var -e test.2.0.result.var -D
d5c737
+	@cmp test.2.0.result.var test.2.0.result.var
d5c737
+	@rm test.2.0.*
d5c737
+	@echo passed
d5c737
+	@echo test importing from DMPSTORE and exporting to libefivar
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -n {grub}-GRUB_ENV -f test.2.result.env -D -e test.2.1.goal.var
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -i test.2.1.goal.var -e test.2.1.result.var
d5c737
+	@cmp test.2.1.result.var test.2.1.result.var
d5c737
+	@rm test.2.1.*
d5c737
+	@echo passed
d5c737
+	@echo test importing from libefivar and exporting to DMPSTORE and mixed-case guid-name validation
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -n 91376aff-cBa6-42bE-949d-06fde81128e8-GRUB_ENV -f test.2.result.env -e test.2.2.goal.var
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -i test.2.2.goal.var -e test.2.2.result.var -D
d5c737
+	@cmp test.2.2.result.var test.2.2.result.var
d5c737
+	@rm test.2.2.*
d5c737
+	@echo passed
d5c737
+	@echo test importing from libefivar and exporting to libefivar and guid-name validation
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -n 91376aff-cba6-42be-949d-06fde81128e8-GRUB_ENV -f test.2.result.env -e test.2.3.goal.var
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -i test.2.3.goal.var -e test.2.3.result.var
d5c737
+	@cmp test.2.3.result.var test.2.3.result.var
d5c737
+	@rm test.2.3.* test.2.result.env
d5c737
+	@echo passed
d5c737
+	@echo testing efivar -L
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -L | \
d5c737
+		grep -q '^{91376aff-cba6-42be-949d-06fde81128e8} {grub} efi_guid_grub GRUB$$'
d5c737
+	@echo passed
d5c737
+
d5c737
+test3:
d5c737
+	@echo testing with BootOrder variable dmpstore generated
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -i test.3.goal.var -e test.3.0.result.var
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -i test.3.0.result.var -e test.3.1.result.var -D
d5c737
+	@cmp test.3.goal.var test.3.1.result.var
d5c737
+	@rm test.3.0.result.var test.3.1.result.var
d5c737
+	@echo passed
d5c737
+
d5c737
+test4:
d5c737
+	@echo testing with ConIn variable dmpstore generated
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -i test.4.goal.var -e test.4.0.result.var
d5c737
+	@LD_LIBRARY_PATH=$(TOPDIR)/src $(EFIVAR) -i test.4.0.result.var -e test.4.1.result.var -D
d5c737
+	@cmp test.4.goal.var test.4.1.result.var
d5c737
+	@rm test.4.0.result.var test.4.1.result.var
d5c737
+	@echo passed
d5c737
+
d5c737
+.PHONY: all clean test0
d5c737
+# vim:ft=make
d5c737
+#
d5c737
diff --git a/tests/test.0.goal.var b/tests/test.0.goal.var
d5c737
new file mode 100644
d5c737
index 0000000000000000000000000000000000000000..a3bfb4db5ea49c8b26b0b9a0e118da4109969efb
d5c737
GIT binary patch
d5c737
literal 562
d5c737
zcmWe)00Jfk26u)ahEN74hIj^720w-{py2;3^NGt&?{k_mm+kKhL5&yeKrv+n_n=TG
d5c737
z1=qZ?%%c3f+|;}h1*e?+
d5c737
Jz?Da0CID%RU7r8|
d5c737
d5c737
literal 0
d5c737
HcmV?d00001
d5c737
d5c737
diff --git a/tests/test.1.goal.var b/tests/test.1.goal.var
d5c737
new file mode 100644
d5c737
index 0000000000000000000000000000000000000000..7f70c93317d996c429430ec434098c0417370970
d5c737
GIT binary patch
d5c737
literal 574
d5c737
zcmbO(djB&c0|Ns)5QD(~Ec1!WPVaM?GMDY|3qg$+LLfmV1_pPAAcjx|Cx&
d5c737
zFrc8af_qS?lY(nrS!PjwUT$h$iGov3esVTfN@`MRx@}@kj*f0|a#3bMNoHQUj&4qB
d5c737
SMQRb3@+cTCAs{>T<#Pa%YGIxL
d5c737
d5c737
literal 0
d5c737
HcmV?d00001
d5c737
d5c737
diff --git a/tests/test.3.goal.var b/tests/test.3.goal.var
d5c737
new file mode 100644
d5c737
index 0000000000000000000000000000000000000000..972dd553e2043e782b096c9a8ad509c07b73782d
d5c737
GIT binary patch
d5c737
literal 66
d5c737
zcmWe(U|`?_Vkd@tAS_|<XDDJwVMqm%3=E0)pLCy^d`WN>FT;Zw%-TKdKru!JW+2JL
d5c737
Pz{0@Fz{b#`@+=nsxhf5!
d5c737
d5c737
literal 0
d5c737
HcmV?d00001
d5c737
d5c737
diff --git a/tests/test.4.goal.var b/tests/test.4.goal.var
d5c737
new file mode 100644
d5c737
index 0000000000000000000000000000000000000000..549ed5b717dd23843883d3d45f65f4dafeede870
d5c737
GIT binary patch
d5c737
literal 365
d5c737
zcmWe)U|_IjWMFV+$Y;o7@C0HPhE#?!plIU#C*7weUlLr!%kW?Zvvv;~P>hj9gu%OZ
d5c737
z#$~DL@y<Q#J=0$&6*)5V2?J$-U>bztU}R+G5@85-KlotZ&r5={co-(A+aL6;XJjEo
d5c737
zduqb6`;uEO3(nFdOFQ@Rb=42T%Y6FU_2+4DG&_@MdqeKT+KtgYu1oqK#orBlKZQi?
d5c737
e*A|Gbebas3YeDe^+2?h-9rgcN7(R2c?F0Zk6=943
d5c737
d5c737
literal 0
d5c737
HcmV?d00001
d5c737
d5c737
-- 
d5c737
2.26.2
d5c737