1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
#!/usr/bin/perl
# Copyright (C) 2010 Red Hat Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
# Test the discovery of relationships between LVM PVs, VGs and LVs.
use strict;
use warnings;
use Sys::Guestfs;
my $testimg = "test.img";
unlink $testimg;
open FILE, ">$testimg" or die "$testimg: $!";
truncate FILE, 256*1024*1024 or die "$testimg: truncate: $!";
close FILE or die "$testimg: $!";
my $g = Sys::Guestfs->new ();
#$g->set_verbose (1);
#$g->set_trace (1);
$g->add_drive ($testimg);
$g->launch ();
# Create an arrangement of PVs, VGs and LVs.
$g->sfdiskM ("/dev/sda", [",127", "128,"]);
$g->pvcreate ("/dev/sda1");
$g->pvcreate ("/dev/sda2");
$g->vgcreate ("VG", ["/dev/sda1", "/dev/sda2"]);
$g->lvcreate ("LV1", "VG", 32);
$g->lvcreate ("LV2", "VG", 32);
$g->lvcreate ("LV3", "VG", 32);
# Now let's get the arrangement.
my @pvs = $g->pvs ();
my @lvs = $g->lvs ();
my %pvuuids;
foreach my $pv (@pvs) {
my $uuid = $g->pvuuid ($pv);
$pvuuids{$uuid} = $pv;
}
my %lvuuids;
foreach my $lv (@lvs) {
my $uuid = $g->lvuuid ($lv);
$lvuuids{$uuid} = $lv;
}
# In this case there is only one VG, called "VG", but in a real
# program you'd want to repeat these steps for each VG that you found.
my @pvuuids_in_VG = $g->vgpvuuids ("VG");
my @lvuuids_in_VG = $g->vglvuuids ("VG");
my @pvs_in_VG;
foreach my $uuid (@pvuuids_in_VG) {
push @pvs_in_VG, $pvuuids{$uuid};
}
@pvs_in_VG = sort @pvs_in_VG;
my @lvs_in_VG;
foreach my $uuid (@lvuuids_in_VG) {
push @lvs_in_VG, $lvuuids{$uuid};
}
@lvs_in_VG = sort @lvs_in_VG;
unless (@pvs_in_VG == 2 &&
$pvs_in_VG[0] eq "/dev/vda1" && $pvs_in_VG[1] eq "/dev/vda2") {
die "unexpected set of PVs for volume group VG: [",
join (", ", @pvs_in_VG), "]\n"
}
unless (@lvs_in_VG == 3 &&
$lvs_in_VG[0] eq "/dev/VG/LV1" &&
$lvs_in_VG[1] eq "/dev/VG/LV2" &&
$lvs_in_VG[2] eq "/dev/VG/LV3") {
die "unexpected set of LVs for volume group VG: [",
join (", ", @lvs_in_VG), "]\n"
}
undef $g;
unlink $testimg or die "$testimg: unlink: $!";
|