|
|
0cb0b9 |
From e76ec6107f63fbf17cc6daf00a9cdb21994e54c1 Mon Sep 17 00:00:00 2001
|
|
|
0cb0b9 |
From: Wang Dong <dongdwdw@linux.vnet.ibm.com>
|
|
|
0cb0b9 |
Date: Thu, 20 Apr 2017 10:20:07 +0200
|
|
|
0cb0b9 |
Subject: [PATCH 75/75] libparted/dasd: add test cases for the new fdasd
|
|
|
0cb0b9 |
functions
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
The test case uses a temporary file in libparted/tests under
|
|
|
0cb0b9 |
Check framwork.It can be issued by "make check" in the test dir.
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
Signed-off-by: Wang Dong <dongdwdw@linux.vnet.ibm.com>
|
|
|
0cb0b9 |
Signed-off-by: Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
|
|
|
0cb0b9 |
---
|
|
|
0cb0b9 |
libparted/tests/t4000-volser.sh | 20 +++++
|
|
|
0cb0b9 |
libparted/tests/volser.c | 188 ++++++++++++++++++++++++++++++++++++++++
|
|
|
0cb0b9 |
2 files changed, 208 insertions(+)
|
|
|
0cb0b9 |
create mode 100755 libparted/tests/t4000-volser.sh
|
|
|
0cb0b9 |
create mode 100644 libparted/tests/volser.c
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
diff --git a/libparted/tests/t4000-volser.sh b/libparted/tests/t4000-volser.sh
|
|
|
0cb0b9 |
new file mode 100755
|
|
|
0cb0b9 |
index 0000000..89688ba
|
|
|
0cb0b9 |
--- /dev/null
|
|
|
0cb0b9 |
+++ b/libparted/tests/t4000-volser.sh
|
|
|
0cb0b9 |
@@ -0,0 +1,20 @@
|
|
|
0cb0b9 |
+#!/bin/sh
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+# This program is free software; you can redistribute it and/or modify
|
|
|
0cb0b9 |
+# it under the terms of the GNU General Public License as published by
|
|
|
0cb0b9 |
+# the Free Software Foundation; either version 3 of the License, or
|
|
|
0cb0b9 |
+# (at your option) any later version.
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+# This program is distributed in the hope that it will be useful,
|
|
|
0cb0b9 |
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
0cb0b9 |
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
0cb0b9 |
+# GNU General Public License for more details.
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+# You should have received a copy of the GNU General Public License
|
|
|
0cb0b9 |
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+. "${top_srcdir=../..}/tests/init.sh"; path_prepend_ .
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+volser || fail=1
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+Exit $fail
|
|
|
0cb0b9 |
diff --git a/libparted/tests/volser.c b/libparted/tests/volser.c
|
|
|
0cb0b9 |
new file mode 100644
|
|
|
0cb0b9 |
index 0000000..9063821
|
|
|
0cb0b9 |
--- /dev/null
|
|
|
0cb0b9 |
+++ b/libparted/tests/volser.c
|
|
|
0cb0b9 |
@@ -0,0 +1,188 @@
|
|
|
0cb0b9 |
+/*
|
|
|
0cb0b9 |
+ * Author: Wang Dong <dongdwdw@cn.ibm.com>
|
|
|
0cb0b9 |
+ */
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+#include <config.h>
|
|
|
0cb0b9 |
+#include <unistd.h>
|
|
|
0cb0b9 |
+#include <check.h>
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+#include <parted/vtoc.h>
|
|
|
0cb0b9 |
+#include <parted/device.h>
|
|
|
0cb0b9 |
+#include <parted/fdasd.h>
|
|
|
0cb0b9 |
+#include <parted/vtoc.h>
|
|
|
0cb0b9 |
+#include "../arch/linux.h"
|
|
|
0cb0b9 |
+#include "common.h"
|
|
|
0cb0b9 |
+#include "progname.h"
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+/* set dasd first */
|
|
|
0cb0b9 |
+static char vol_devno[7] = {0};
|
|
|
0cb0b9 |
+static char *tmp_disk;
|
|
|
0cb0b9 |
+static int fd;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+static PedDisk *disk;
|
|
|
0cb0b9 |
+static struct fdasd_anchor anc;
|
|
|
0cb0b9 |
+static fdasd_anchor_t *anchor = &anc;
|
|
|
0cb0b9 |
+static LinuxSpecific *arch_specific;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+/* set the enviroment */
|
|
|
0cb0b9 |
+static void set_test (void)
|
|
|
0cb0b9 |
+{
|
|
|
0cb0b9 |
+ PedDevice *dev;
|
|
|
0cb0b9 |
+ PedDiskType *type;
|
|
|
0cb0b9 |
+ type = ped_disk_type_get ("dasd");
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ tmp_disk = _create_disk (20*1024*1024);
|
|
|
0cb0b9 |
+ fail_if (tmp_disk == NULL, "Failed to create temporary disk");
|
|
|
0cb0b9 |
+ dev = ped_device_get (tmp_disk);
|
|
|
0cb0b9 |
+ if (dev == NULL)
|
|
|
0cb0b9 |
+ return;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ disk = _create_disk_label (dev, type);
|
|
|
0cb0b9 |
+ if (!ped_device_open (disk->dev))
|
|
|
0cb0b9 |
+ return;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ fdasd_initialize_anchor (anchor);
|
|
|
0cb0b9 |
+ arch_specific = LINUX_SPECIFIC (disk->dev);
|
|
|
0cb0b9 |
+ fd = arch_specific->fd;
|
|
|
0cb0b9 |
+ if (!fdasd_get_geometry (dev, anchor, fd))
|
|
|
0cb0b9 |
+ return;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ fdasd_check_volume (anchor, fd);
|
|
|
0cb0b9 |
+ sprintf (vol_devno, "0X%04x", anchor->devno);
|
|
|
0cb0b9 |
+ ck_assert (strlen (vol_devno) == VOLSER_LENGTH);
|
|
|
0cb0b9 |
+}
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+static void free_test (void)
|
|
|
0cb0b9 |
+{
|
|
|
0cb0b9 |
+ ped_device_close (disk->dev);
|
|
|
0cb0b9 |
+ ped_device_destroy (disk->dev);
|
|
|
0cb0b9 |
+ unlink (tmp_disk);
|
|
|
0cb0b9 |
+ free (tmp_disk);
|
|
|
0cb0b9 |
+ fdasd_cleanup (anchor);
|
|
|
0cb0b9 |
+}
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+/* Test with default volser */
|
|
|
0cb0b9 |
+START_TEST (test_get_volser)
|
|
|
0cb0b9 |
+{
|
|
|
0cb0b9 |
+ char volser[7] = {0};
|
|
|
0cb0b9 |
+ fdasd_change_volser (anchor, vol_devno);
|
|
|
0cb0b9 |
+ fdasd_write_labels (anchor, fd);
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ fdasd_get_volser (anchor, volser, fd);
|
|
|
0cb0b9 |
+ ck_assert (!strcmp (volser, vol_devno));
|
|
|
0cb0b9 |
+}
|
|
|
0cb0b9 |
+END_TEST
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+START_TEST (test_check_volser)
|
|
|
0cb0b9 |
+{
|
|
|
0cb0b9 |
+ char vol[7] = {0};
|
|
|
0cb0b9 |
+ char vol_long[] = "abcdefg";
|
|
|
0cb0b9 |
+ char vol_short[] = "ab_c ";
|
|
|
0cb0b9 |
+ char vol_null[] = " ";
|
|
|
0cb0b9 |
+ char *vol_input = NULL;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ vol_input = vol_long;
|
|
|
0cb0b9 |
+ fdasd_check_volser (vol_input, anchor->devno);
|
|
|
0cb0b9 |
+ ck_assert(!strcmp (vol_input, "ABCDEF"));
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ vol_input = vol_short;
|
|
|
0cb0b9 |
+ fdasd_check_volser (vol_input, anchor->devno);
|
|
|
0cb0b9 |
+ ck_assert (!strcmp (vol_input, "ABC"));
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ vol_input = vol_null;
|
|
|
0cb0b9 |
+ fdasd_check_volser (vol_input, anchor->devno);
|
|
|
0cb0b9 |
+ ck_assert (!strcmp (vol_input, vol_devno));
|
|
|
0cb0b9 |
+}
|
|
|
0cb0b9 |
+END_TEST
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+START_TEST (test_change_volser)
|
|
|
0cb0b9 |
+{
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ char vol[] = "000000";
|
|
|
0cb0b9 |
+ char volser[7] = {0};
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ fdasd_change_volser (anchor, vol);
|
|
|
0cb0b9 |
+ fdasd_write_labels (anchor, fd);
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ fdasd_get_volser (anchor, volser, fd);
|
|
|
0cb0b9 |
+ ck_assert (!strcmp (volser, vol));
|
|
|
0cb0b9 |
+}
|
|
|
0cb0b9 |
+END_TEST
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+/*
|
|
|
0cb0b9 |
+ * fdsad_recreate_vtoc recreate the VTOC with existing one.
|
|
|
0cb0b9 |
+ * So the partition information should be not changed after recreating
|
|
|
0cb0b9 |
+ * VTOC.
|
|
|
0cb0b9 |
+*/
|
|
|
0cb0b9 |
+START_TEST (test_reuse_vtoc)
|
|
|
0cb0b9 |
+{
|
|
|
0cb0b9 |
+ ds5ext_t before;
|
|
|
0cb0b9 |
+ ds5ext_t after;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ memcpy (&before, &anchor->f5->DS5AVEXT, sizeof(ds5ext_t));
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ if (anchor->fspace_trk) {
|
|
|
0cb0b9 |
+ fdasd_reuse_vtoc (anchor);
|
|
|
0cb0b9 |
+ memcpy (&after, &anchor->f5->DS5AVEXT, sizeof(ds5ext_t));
|
|
|
0cb0b9 |
+ if ((before.t != after.t) && (before.fc != after.fc) && (before.ft != after.ft))
|
|
|
0cb0b9 |
+ ck_abort ();
|
|
|
0cb0b9 |
+ } else {
|
|
|
0cb0b9 |
+ fdasd_reuse_vtoc (anchor);
|
|
|
0cb0b9 |
+ memcpy (&after, &anchor->f5->DS5AVEXT, sizeof(ds5ext_t));
|
|
|
0cb0b9 |
+ if ((before.t != after.t) && (before.fc != after.fc) && (before.ft != after.ft))
|
|
|
0cb0b9 |
+ ck_abort ();
|
|
|
0cb0b9 |
+ }
|
|
|
0cb0b9 |
+}
|
|
|
0cb0b9 |
+END_TEST
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+int main (int argc, char **argv)
|
|
|
0cb0b9 |
+{
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ set_program_name (argv[0]);
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+#if defined __s390__ || defined __s390x__
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ int number_failed = 0;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ Suite *suite = suite_create ("Volser");
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ TCase *tcase_get = tcase_create ("Get");
|
|
|
0cb0b9 |
+ TCase *tcase_check = tcase_create ("Check");
|
|
|
0cb0b9 |
+ TCase *tcase_change = tcase_create ("Change");
|
|
|
0cb0b9 |
+ TCase *tcase_vtoc = tcase_create ("Vtoc");
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ ped_exception_set_handler (_test_exception_handler);
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ tcase_add_checked_fixture (tcase_check, set_test, free_test);
|
|
|
0cb0b9 |
+ tcase_add_test (tcase_check, test_check_volser);
|
|
|
0cb0b9 |
+ tcase_set_timeout (tcase_check, 0);
|
|
|
0cb0b9 |
+ suite_add_tcase (suite, tcase_check);
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ tcase_add_checked_fixture (tcase_change, set_test, free_test);
|
|
|
0cb0b9 |
+ tcase_add_test (tcase_change, test_change_volser);
|
|
|
0cb0b9 |
+ tcase_set_timeout (tcase_change, 0);
|
|
|
0cb0b9 |
+ suite_add_tcase (suite, tcase_change);
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ tcase_add_checked_fixture (tcase_get, set_test, free_test);
|
|
|
0cb0b9 |
+ tcase_add_test (tcase_get, test_get_volser);
|
|
|
0cb0b9 |
+ tcase_set_timeout (tcase_get, 0);
|
|
|
0cb0b9 |
+ suite_add_tcase (suite, tcase_get);
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ tcase_add_checked_fixture (tcase_vtoc, set_test, free_test);
|
|
|
0cb0b9 |
+ tcase_add_test (tcase_vtoc, test_reuse_vtoc);
|
|
|
0cb0b9 |
+ tcase_set_timeout (tcase_vtoc, 0);
|
|
|
0cb0b9 |
+ suite_add_tcase (suite, tcase_vtoc);
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ SRunner *srunner = srunner_create (suite);
|
|
|
0cb0b9 |
+ /* When to debug, uncomment this line */
|
|
|
0cb0b9 |
+ /* srunner_set_fork_status (srunner, CK_NOFORK); */
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ srunner_run_all (srunner, CK_VERBOSE);
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ number_failed = srunner_ntests_failed (srunner);
|
|
|
0cb0b9 |
+ srunner_free (srunner);
|
|
|
0cb0b9 |
+ return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+#endif
|
|
|
0cb0b9 |
+ return 0;
|
|
|
0cb0b9 |
+}
|
|
|
0cb0b9 |
--
|
|
|
0cb0b9 |
2.9.3
|
|
|
0cb0b9 |
|