manageiq-smartstate 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +15 -0
- data/.rspec +4 -0
- data/.rspec_ci +4 -0
- data/.travis.yml +15 -0
- data/Gemfile +9 -0
- data/LICENSE.txt +202 -0
- data/README.md +45 -0
- data/Rakefile +23 -0
- data/bin/console +14 -0
- data/bin/setup +8 -0
- data/lib/MiqContainerGroup/MiqContainerGroup.rb +31 -0
- data/lib/MiqVm/MiqLocalVm.rb +50 -0
- data/lib/MiqVm/MiqRhevmVm.rb +179 -0
- data/lib/MiqVm/MiqVm.rb +355 -0
- data/lib/MiqVm/miq_azure_vm.rb +96 -0
- data/lib/MiqVm/miq_scvmm_vm.rb +38 -0
- data/lib/MiqVm/test/camcorder_fleece_test.rb +60 -0
- data/lib/MiqVm/test/localVm.rb +45 -0
- data/lib/MiqVm/test/partitionAlignmentCheck.rb +76 -0
- data/lib/MiqVm/test/remoteVm.rb +65 -0
- data/lib/MiqVm/test/rhevmNfsTest.rb +62 -0
- data/lib/MiqVm/test/rhevmNfsTest2.rb +66 -0
- data/lib/MiqVm/test/rhevmTest.rb +70 -0
- data/lib/OpenStackExtract/MiqOpenStackVm/MiqOpenStackCommon.rb +107 -0
- data/lib/OpenStackExtract/MiqOpenStackVm/MiqOpenStackImage.rb +67 -0
- data/lib/OpenStackExtract/MiqOpenStackVm/MiqOpenStackInstance.rb +182 -0
- data/lib/Scvmm/miq_hyperv_disk.rb +273 -0
- data/lib/Scvmm/miq_scvmm_parse_powershell.rb +75 -0
- data/lib/Scvmm/miq_scvmm_vm_ssa_info.rb +135 -0
- data/lib/Scvmm/test/miq_hyperv_disk_test.rb +33 -0
- data/lib/Scvmm/test/miq_scvmm_vm_ssa_info_test.rb +41 -0
- data/lib/VmLocalDiskAccess/test/localCfg.rb +97 -0
- data/lib/VolumeManager/LVM/logical_volume.rb +75 -0
- data/lib/VolumeManager/LVM/lv_segment.rb +43 -0
- data/lib/VolumeManager/LVM/lvm2disk.rb +158 -0
- data/lib/VolumeManager/LVM/parser.rb +138 -0
- data/lib/VolumeManager/LVM/physical_volume.rb +19 -0
- data/lib/VolumeManager/LVM/scanner.rb +156 -0
- data/lib/VolumeManager/LVM/thin/btree.rb +83 -0
- data/lib/VolumeManager/LVM/thin/constants.rb +86 -0
- data/lib/VolumeManager/LVM/thin/data_map.rb +44 -0
- data/lib/VolumeManager/LVM/thin/mapping_tree.rb +19 -0
- data/lib/VolumeManager/LVM/thin/space_maps.rb +58 -0
- data/lib/VolumeManager/LVM/thin/superblock.rb +136 -0
- data/lib/VolumeManager/LVM/thin.rb +6 -0
- data/lib/VolumeManager/LVM/volume_group.rb +97 -0
- data/lib/VolumeManager/LVM.rb +8 -0
- data/lib/VolumeManager/MiqLdm.rb +546 -0
- data/lib/VolumeManager/MiqLvm.rb +17 -0
- data/lib/VolumeManager/MiqNativeVolumeManager.rb +150 -0
- data/lib/VolumeManager/MiqVolumeManager.rb +277 -0
- data/lib/VolumeManager/VolMgrPlatformSupport.rb +18 -0
- data/lib/VolumeManager/VolMgrPlatformSupportLinux.rb +77 -0
- data/lib/VolumeManager/VolMgrPlatformSupportWin.rb +17 -0
- data/lib/VolumeManager/test/blockDevTest.rb +40 -0
- data/lib/VolumeManager/test/ldm.rb +97 -0
- data/lib/blackbox/VmBlackBox.rb +103 -0
- data/lib/blackbox/xmlStorage.rb +180 -0
- data/lib/db/MiqBdb/MiqBdb.rb +309 -0
- data/lib/db/MiqBdb/MiqBdbBtree.rb +219 -0
- data/lib/db/MiqBdb/MiqBdbHash.rb +199 -0
- data/lib/db/MiqBdb/MiqBdbPage.rb +159 -0
- data/lib/db/MiqBdb/MiqBdbUtil.rb +18 -0
- data/lib/db/MiqSqlite/MiqSqlite3.rb +330 -0
- data/lib/db/MiqSqlite/MiqSqlite3Cell.rb +167 -0
- data/lib/db/MiqSqlite/MiqSqlite3Page.rb +151 -0
- data/lib/db/MiqSqlite/MiqSqlite3Table.rb +124 -0
- data/lib/db/MiqSqlite/MiqSqlite3Util.rb +32 -0
- data/lib/disk/DiskProbe.rb +68 -0
- data/lib/disk/MiqDisk.rb +317 -0
- data/lib/disk/camcorder_test.rb +90 -0
- data/lib/disk/dos_mbr.img +0 -0
- data/lib/disk/modules/AzureBlobDisk.rb +101 -0
- data/lib/disk/modules/LocalDevMod.rb +47 -0
- data/lib/disk/modules/LocalDevProbe.rb +6 -0
- data/lib/disk/modules/MSCommon.rb +352 -0
- data/lib/disk/modules/MSVSDiffDisk.rb +91 -0
- data/lib/disk/modules/MSVSDiskProbe.rb +61 -0
- data/lib/disk/modules/MSVSDynamicDisk.rb +42 -0
- data/lib/disk/modules/MSVSFixedDisk.rb +45 -0
- data/lib/disk/modules/MiqLargeFile.rb +63 -0
- data/lib/disk/modules/MiqLargeFileWin32.rb +107 -0
- data/lib/disk/modules/QcowDisk.rb +692 -0
- data/lib/disk/modules/QcowDiskProbe.rb +34 -0
- data/lib/disk/modules/RawBlockIO.rb +116 -0
- data/lib/disk/modules/RawDisk.rb +45 -0
- data/lib/disk/modules/RawDiskProbe.rb +7 -0
- data/lib/disk/modules/RhevmDescriptor.rb +167 -0
- data/lib/disk/modules/RhevmDiskProbe.rb +52 -0
- data/lib/disk/modules/VMWareCowdDisk.rb +207 -0
- data/lib/disk/modules/VMWareDescriptor.rb +214 -0
- data/lib/disk/modules/VMWareDiskProbe.rb +74 -0
- data/lib/disk/modules/VMWareSparseDisk.rb +189 -0
- data/lib/disk/modules/VhdxDisk.rb +625 -0
- data/lib/disk/modules/VhdxDiskProbe.rb +46 -0
- data/lib/disk/modules/VixDiskMod.rb +54 -0
- data/lib/disk/modules/VixDiskProbe.rb +6 -0
- data/lib/disk/modules/miq_disk_cache.rb +135 -0
- data/lib/disk/modules/miq_dummy_disk.rb +41 -0
- data/lib/disk/modules/vhdx_bat_entry.rb +10 -0
- data/lib/disk/test.rb +66 -0
- data/lib/fs/MetakitFS/MetakitFS.rb +530 -0
- data/lib/fs/MetakitFS/test/Makefile +14 -0
- data/lib/fs/MetakitFS/test/MkCollectFiles.rb +165 -0
- data/lib/fs/MetakitFS/test/MkSelectFiles.rb +30 -0
- data/lib/fs/MetakitFS/test/collect_files.yaml +70 -0
- data/lib/fs/MetakitFS/test/init.rb +3 -0
- data/lib/fs/MetakitFS/test/mk2vmdk.rb +64 -0
- data/lib/fs/MetakitFS/test/mk4test.c +92 -0
- data/lib/fs/MetakitFS/test/mkFsTest.rb +113 -0
- data/lib/fs/MetakitFS/test/proto.rb +97 -0
- data/lib/fs/MiqFS/FsProbe.rb +39 -0
- data/lib/fs/MiqFS/MiqFS.rb +515 -0
- data/lib/fs/MiqFS/modules/AUFSProbe.rb +26 -0
- data/lib/fs/MiqFS/modules/Ext3.rb +305 -0
- data/lib/fs/MiqFS/modules/Ext3Probe.rb +25 -0
- data/lib/fs/MiqFS/modules/Ext4.rb +304 -0
- data/lib/fs/MiqFS/modules/Ext4Probe.rb +25 -0
- data/lib/fs/MiqFS/modules/Fat32.rb +318 -0
- data/lib/fs/MiqFS/modules/Fat32Probe.rb +30 -0
- data/lib/fs/MiqFS/modules/HFSProbe.rb +18 -0
- data/lib/fs/MiqFS/modules/Iso9660.rb +293 -0
- data/lib/fs/MiqFS/modules/Iso9660Probe.rb +18 -0
- data/lib/fs/MiqFS/modules/LocalFS.rb +105 -0
- data/lib/fs/MiqFS/modules/NTFS.rb +287 -0
- data/lib/fs/MiqFS/modules/NTFSProbe.rb +21 -0
- data/lib/fs/MiqFS/modules/NativeFS.rb +155 -0
- data/lib/fs/MiqFS/modules/ReFSProbe.rb +17 -0
- data/lib/fs/MiqFS/modules/RealFS.rb +79 -0
- data/lib/fs/MiqFS/modules/RealFSProbe.rb +6 -0
- data/lib/fs/MiqFS/modules/Reiser4Probe.rb +18 -0
- data/lib/fs/MiqFS/modules/ReiserFS.rb +315 -0
- data/lib/fs/MiqFS/modules/ReiserFSProbe.rb +42 -0
- data/lib/fs/MiqFS/modules/UnionFSProbe.rb +18 -0
- data/lib/fs/MiqFS/modules/WebDAV.rb +127 -0
- data/lib/fs/MiqFS/modules/WebDAVFile.rb +68 -0
- data/lib/fs/MiqFS/modules/XFS.rb +300 -0
- data/lib/fs/MiqFS/modules/XFSProbe.rb +26 -0
- data/lib/fs/MiqFS/modules/ZFSProbe.rb +18 -0
- data/lib/fs/MiqFS/test.rb +59 -0
- data/lib/fs/MiqFsUtil.rb +383 -0
- data/lib/fs/MiqMountManager.rb +209 -0
- data/lib/fs/MiqNativeMountManager.rb +101 -0
- data/lib/fs/MountManagerProbe.rb +29 -0
- data/lib/fs/ReiserFS/block.rb +209 -0
- data/lib/fs/ReiserFS/directory.rb +136 -0
- data/lib/fs/ReiserFS/directory_entry.rb +140 -0
- data/lib/fs/ReiserFS/file_data.rb +111 -0
- data/lib/fs/ReiserFS/superblock.rb +140 -0
- data/lib/fs/ReiserFS/utils.rb +95 -0
- data/lib/fs/VimDatastoreFS/VimDatastoreFS.rb +192 -0
- data/lib/fs/ext3/alloc_bitmap.rb +38 -0
- data/lib/fs/ext3/block_pointers_path.rb +130 -0
- data/lib/fs/ext3/directory.rb +51 -0
- data/lib/fs/ext3/directory_entry.rb +67 -0
- data/lib/fs/ext3/ex_attrib_header.rb +14 -0
- data/lib/fs/ext3/ex_attrib_name.rb +23 -0
- data/lib/fs/ext3/file_data.rb +130 -0
- data/lib/fs/ext3/group_descriptor_entry.rb +65 -0
- data/lib/fs/ext3/group_descriptor_table.rb +54 -0
- data/lib/fs/ext3/hash_tree_entry.rb +18 -0
- data/lib/fs/ext3/hash_tree_header.rb +15 -0
- data/lib/fs/ext3/inode.rb +228 -0
- data/lib/fs/ext3/posix_acl_entry.rb +29 -0
- data/lib/fs/ext3/posix_acl_header.rb +11 -0
- data/lib/fs/ext3/superblock.rb +406 -0
- data/lib/fs/ext3/test/tc_Ext3BlockPointersPath.rb +74 -0
- data/lib/fs/ext4/alloc_bitmap.rb +38 -0
- data/lib/fs/ext4/directory.rb +87 -0
- data/lib/fs/ext4/directory_entry.rb +77 -0
- data/lib/fs/ext4/ex_attrib_header.rb +14 -0
- data/lib/fs/ext4/ex_attrib_name.rb +23 -0
- data/lib/fs/ext4/extent.rb +35 -0
- data/lib/fs/ext4/extent_header.rb +40 -0
- data/lib/fs/ext4/extent_index.rb +33 -0
- data/lib/fs/ext4/group_descriptor_entry.rb +69 -0
- data/lib/fs/ext4/group_descriptor_table.rb +54 -0
- data/lib/fs/ext4/hash_tree_entry.rb +58 -0
- data/lib/fs/ext4/hash_tree_header.rb +35 -0
- data/lib/fs/ext4/inode.rb +465 -0
- data/lib/fs/ext4/posix_acl_entry.rb +29 -0
- data/lib/fs/ext4/posix_acl_header.rb +11 -0
- data/lib/fs/ext4/superblock.rb +412 -0
- data/lib/fs/fat32/boot_sect.rb +379 -0
- data/lib/fs/fat32/directory.rb +222 -0
- data/lib/fs/fat32/directory_entry.rb +540 -0
- data/lib/fs/fat32/file_data.rb +128 -0
- data/lib/fs/iso9660/boot_sector.rb +170 -0
- data/lib/fs/iso9660/directory.rb +90 -0
- data/lib/fs/iso9660/directory_entry.rb +147 -0
- data/lib/fs/iso9660/file_data.rb +78 -0
- data/lib/fs/iso9660/rock_ridge.rb +329 -0
- data/lib/fs/iso9660/util.rb +57 -0
- data/lib/fs/modules/LinuxMount.rb +300 -0
- data/lib/fs/modules/LinuxMountProbe.rb +29 -0
- data/lib/fs/modules/WinMount.rb +97 -0
- data/lib/fs/modules/WinMountProbe.rb +24 -0
- data/lib/fs/ntfs/attrib_attribute_list.rb +131 -0
- data/lib/fs/ntfs/attrib_bitmap.rb +26 -0
- data/lib/fs/ntfs/attrib_data.rb +74 -0
- data/lib/fs/ntfs/attrib_file_name.rb +110 -0
- data/lib/fs/ntfs/attrib_header.rb +194 -0
- data/lib/fs/ntfs/attrib_index_allocation.rb +19 -0
- data/lib/fs/ntfs/attrib_index_root.rb +247 -0
- data/lib/fs/ntfs/attrib_object_id.rb +40 -0
- data/lib/fs/ntfs/attrib_standard_information.rb +107 -0
- data/lib/fs/ntfs/attrib_type.rb +49 -0
- data/lib/fs/ntfs/attrib_volume_information.rb +53 -0
- data/lib/fs/ntfs/attrib_volume_name.rb +31 -0
- data/lib/fs/ntfs/boot_sect.rb +253 -0
- data/lib/fs/ntfs/data_run.rb +358 -0
- data/lib/fs/ntfs/directory_index_node.rb +114 -0
- data/lib/fs/ntfs/index_node_header.rb +69 -0
- data/lib/fs/ntfs/index_record_header.rb +85 -0
- data/lib/fs/ntfs/mft_entry.rb +288 -0
- data/lib/fs/ntfs/utils.rb +43 -0
- data/lib/fs/test/camcorder_fs_test.rb +108 -0
- data/lib/fs/test/collect_files_direct.yaml +22 -0
- data/lib/fs/test/collect_files_in.yaml +24 -0
- data/lib/fs/test/collect_files_in_nc.yaml +22 -0
- data/lib/fs/test/collect_files_out.yaml +6 -0
- data/lib/fs/test/collect_files_rm.yaml +6 -0
- data/lib/fs/test/copyTest.rb +126 -0
- data/lib/fs/test/fsTest.rb +87 -0
- data/lib/fs/test/updateTest.rb +184 -0
- data/lib/fs/xfs/allocation_group.rb +160 -0
- data/lib/fs/xfs/bmap_btree_block.rb +125 -0
- data/lib/fs/xfs/bmap_btree_record.rb +80 -0
- data/lib/fs/xfs/bmap_btree_root_node.rb +72 -0
- data/lib/fs/xfs/directory.rb +133 -0
- data/lib/fs/xfs/directory2_data_header.rb +27 -0
- data/lib/fs/xfs/directory3_data_header.rb +34 -0
- data/lib/fs/xfs/directory_block_tail.rb +22 -0
- data/lib/fs/xfs/directory_data_header.rb +46 -0
- data/lib/fs/xfs/directory_entry.rb +106 -0
- data/lib/fs/xfs/inode.rb +532 -0
- data/lib/fs/xfs/inode_map.rb +100 -0
- data/lib/fs/xfs/short_form_directory_entry.rb +91 -0
- data/lib/fs/xfs/short_form_header.rb +44 -0
- data/lib/fs/xfs/superblock.rb +556 -0
- data/lib/lib/tasks/azure.rake +52 -0
- data/lib/manageiq/smartstate/version.rb +5 -0
- data/lib/manageiq/smartstate.rb +7 -0
- data/lib/manageiq-smartstate.rb +1 -0
- data/lib/metadata/MIQExtract/MIQExtract.rb +297 -0
- data/lib/metadata/MIQExtract/test/extractTest.rb +41 -0
- data/lib/metadata/MIQExtract/test/full_extract_test.rb +68 -0
- data/lib/metadata/ScanProfile/HostScanItem.rb +4 -0
- data/lib/metadata/ScanProfile/HostScanProfile.rb +4 -0
- data/lib/metadata/ScanProfile/HostScanProfiles.rb +41 -0
- data/lib/metadata/ScanProfile/ScanItemBase.rb +63 -0
- data/lib/metadata/ScanProfile/ScanProfileBase.rb +51 -0
- data/lib/metadata/ScanProfile/ScanProfilesBase.rb +60 -0
- data/lib/metadata/ScanProfile/VmScanItem.rb +4 -0
- data/lib/metadata/ScanProfile/VmScanProfile.rb +4 -0
- data/lib/metadata/ScanProfile/VmScanProfiles.rb +38 -0
- data/lib/metadata/ScanProfile/modules/HostScanItemFile.rb +51 -0
- data/lib/metadata/ScanProfile/modules/HostScanItemNteventlog.rb +84 -0
- data/lib/metadata/ScanProfile/modules/VmScanItemFile.rb +39 -0
- data/lib/metadata/ScanProfile/modules/VmScanItemNteventlog.rb +34 -0
- data/lib/metadata/ScanProfile/modules/VmScanItemRegistry.rb +64 -0
- data/lib/metadata/VMMount/VMMount.rb +81 -0
- data/lib/metadata/VMMount/VMPlatformMount.rb +18 -0
- data/lib/metadata/VMMount/VMPlatformMountLinux.rb +75 -0
- data/lib/metadata/VMMount/VMPlatformMountWin.rb +13 -0
- data/lib/metadata/VmConfig/GetNativeCfg.rb +45 -0
- data/lib/metadata/VmConfig/VmConfig.rb +947 -0
- data/lib/metadata/VmConfig/cfgConfig.rb +45 -0
- data/lib/metadata/VmConfig/ovfConfig.rb +99 -0
- data/lib/metadata/VmConfig/test/GetVMwareCfgTest.rb +40 -0
- data/lib/metadata/VmConfig/vmcConfig.rb +116 -0
- data/lib/metadata/VmConfig/vmtxConfig.rb +4 -0
- data/lib/metadata/VmConfig/vmxConfig.rb +162 -0
- data/lib/metadata/VmConfig/xmlConfig.rb +79 -0
- data/lib/metadata/VmConfig/xmlMsHyperVConfig.rb +41 -0
- data/lib/metadata/linux/InitProcHash.rb +632 -0
- data/lib/metadata/linux/LinuxInitProcs.rb +142 -0
- data/lib/metadata/linux/LinuxOSInfo.rb +237 -0
- data/lib/metadata/linux/LinuxPackages.rb +209 -0
- data/lib/metadata/linux/LinuxSystemd.rb +130 -0
- data/lib/metadata/linux/LinuxUsers.rb +289 -0
- data/lib/metadata/linux/LinuxUtils.rb +197 -0
- data/lib/metadata/linux/MiqConaryPackages.rb +41 -0
- data/lib/metadata/linux/MiqRpmPackages.rb +160 -0
- data/lib/metadata/linux/test/Name +0 -0
- data/lib/metadata/linux/test/Packages +0 -0
- data/lib/metadata/linux/test/rpoTest.rb +5 -0
- data/lib/metadata/linux/test/tc_LinuxUtils.rb +4157 -0
- data/lib/metadata/util/event_log_filter.rb +61 -0
- data/lib/metadata/util/md5deep.rb +280 -0
- data/lib/metadata/util/win32/Win32Accounts.rb +764 -0
- data/lib/metadata/util/win32/Win32EventLog.rb +743 -0
- data/lib/metadata/util/win32/Win32Services.rb +86 -0
- data/lib/metadata/util/win32/Win32Software.rb +326 -0
- data/lib/metadata/util/win32/Win32System.rb +333 -0
- data/lib/metadata/util/win32/boot_info_win.rb +59 -0
- data/lib/metadata/util/win32/fleece_hives.rb +220 -0
- data/lib/metadata/util/win32/ms-registry.rb +650 -0
- data/lib/metadata/util/win32/peheader.rb +868 -0
- data/lib/metadata/util/win32/remote-registry.rb +142 -0
- data/lib/metadata/util/win32/system_path_win.rb +103 -0
- data/lib/metadata/util/win32/versioninfo.rb +17 -0
- data/manageiq-smartstate.gemspec +35 -0
- metadata +486 -0
@@ -0,0 +1,108 @@
|
|
1
|
+
require 'manageiq-gems-pending'
|
2
|
+
require 'openssl' # Required for 'Digest' in camcorder (< Ruby 2.1)
|
3
|
+
require 'camcorder'
|
4
|
+
require 'log4r'
|
5
|
+
require 'ostruct'
|
6
|
+
require 'disk/MiqDisk'
|
7
|
+
require 'fs/MiqFS/MiqFS'
|
8
|
+
require 'disk/modules/MiqLargeFile'
|
9
|
+
|
10
|
+
#
|
11
|
+
# Formatter to output log messages to the console.
|
12
|
+
#
|
13
|
+
class ConsoleFormatter < Log4r::Formatter
|
14
|
+
def format(event)
|
15
|
+
(event.data.kind_of?(String) ? event.data : event.data.inspect) + "\n"
|
16
|
+
end
|
17
|
+
end
|
18
|
+
$log = Log4r::Logger.new 'toplog'
|
19
|
+
$log.level = Log4r::DEBUG
|
20
|
+
Log4r::StderrOutputter.new('err_console', :formatter => ConsoleFormatter)
|
21
|
+
$log.add 'err_console'
|
22
|
+
|
23
|
+
#
|
24
|
+
# Path to RAW disk image.
|
25
|
+
#
|
26
|
+
VIRTUAL_DISK_FILE = "path to raw disk image file"
|
27
|
+
|
28
|
+
commit = true
|
29
|
+
|
30
|
+
begin
|
31
|
+
recorder = Camcorder::Recorder.new("#{File.dirname(__FILE__)}/foo.yml")
|
32
|
+
Camcorder.default_recorder = recorder
|
33
|
+
Camcorder.intercept_constructor(MiqLargeFile::MiqLargeFileOther) do
|
34
|
+
methods_with_side_effects :seek, :read, :write
|
35
|
+
end
|
36
|
+
Camcorder.intercept_constructor(MiqLargeFile::MiqLargeFileStat)
|
37
|
+
|
38
|
+
recorder.start
|
39
|
+
|
40
|
+
diskInfo = OpenStruct.new
|
41
|
+
diskInfo.rawDisk = true # remove if image is not in RAW format.
|
42
|
+
diskInfo.fileName = VIRTUAL_DISK_FILE
|
43
|
+
|
44
|
+
disk = MiqDisk.getDisk(diskInfo)
|
45
|
+
raise "Failed to open disk: #{diskInfo.fileName}" unless disk
|
46
|
+
|
47
|
+
puts "Disk type: #{disk.diskType}"
|
48
|
+
puts "Disk partition type: #{disk.partType}"
|
49
|
+
puts "Disk block size: #{disk.blockSize}"
|
50
|
+
puts "Disk start LBA: #{disk.lbaStart}"
|
51
|
+
puts "Disk end LBA: #{disk.lbaEnd}"
|
52
|
+
puts "Disk start byte: #{disk.startByteAddr}"
|
53
|
+
puts "Disk end byte: #{disk.endByteAddr}"
|
54
|
+
|
55
|
+
parts = disk.getPartitions || []
|
56
|
+
|
57
|
+
i = 1
|
58
|
+
parts.each do |p|
|
59
|
+
puts "\nPartition #{i}:"
|
60
|
+
puts "\tDisk type: #{p.diskType}"
|
61
|
+
puts "\tPart partition type: #{p.partType}"
|
62
|
+
puts "\tPart block size: #{p.blockSize}"
|
63
|
+
puts "\tPart start LBA: #{p.lbaStart}"
|
64
|
+
puts "\tPart end LBA: #{p.lbaEnd}"
|
65
|
+
puts "\tPart start byte: #{p.startByteAddr}"
|
66
|
+
puts "\tPart end byte: #{p.endByteAddr}"
|
67
|
+
i += 1
|
68
|
+
end
|
69
|
+
|
70
|
+
target_partition = parts.first || disk
|
71
|
+
puts "\nTarget partition: #{target_partition.partNum}"
|
72
|
+
|
73
|
+
raise "No filesystem detected" unless (mfs = MiqFS.getFS(target_partition))
|
74
|
+
|
75
|
+
puts "FS type: #{mfs.fsType}"
|
76
|
+
puts "pwd = #{mfs.pwd}"
|
77
|
+
|
78
|
+
all_paths = mfs.find('/')
|
79
|
+
directories = all_paths.select { |p| mfs.fileDirectory?(p) }
|
80
|
+
files = all_paths.select { |p| mfs.fileFile?(p) }
|
81
|
+
sym_links = all_paths.select { |p| mfs.fileSymLink?(p) }
|
82
|
+
unclassified = all_paths - directories - files - sym_links
|
83
|
+
|
84
|
+
puts "files: #{files.length}"
|
85
|
+
puts "directories: #{directories.length}"
|
86
|
+
puts "sym_links: #{sym_links.length}"
|
87
|
+
puts "unclassified: #{unclassified.length}"
|
88
|
+
puts "total: #{files.length + directories.length + sym_links.length + unclassified.length}"
|
89
|
+
puts "all_paths: #{all_paths.length}"
|
90
|
+
|
91
|
+
unless unclassified.empty?
|
92
|
+
puts
|
93
|
+
puts "unclassified files:"
|
94
|
+
unclassified.each { |p| puts "\t#{p}" }
|
95
|
+
end
|
96
|
+
rescue => err
|
97
|
+
puts err.to_s
|
98
|
+
puts err.backtrace.join("\n")
|
99
|
+
commit = false # don't commit recording on error
|
100
|
+
ensure
|
101
|
+
disk.close if disk
|
102
|
+
if recorder && commit
|
103
|
+
puts
|
104
|
+
puts "camcorder: committing recording..."
|
105
|
+
recorder.commit
|
106
|
+
puts "done."
|
107
|
+
end
|
108
|
+
end
|
@@ -0,0 +1,22 @@
|
|
1
|
+
---
|
2
|
+
-
|
3
|
+
:basedir: "../../.."
|
4
|
+
:todir: "copy_dst_ref"
|
5
|
+
:include:
|
6
|
+
- vmdb
|
7
|
+
:exclude:
|
8
|
+
- !ruby/regexp /\/\.svn/
|
9
|
+
- !ruby/regexp /~$/
|
10
|
+
- !ruby/regexp /\/NTFSCPP/
|
11
|
+
- !ruby/regexp /\/TestVm/
|
12
|
+
- !ruby/regexp /\.c$/
|
13
|
+
- !ruby/regexp /\.h$/
|
14
|
+
- !ruby/regexp /\.o$/
|
15
|
+
- !ruby/regexp /\.vmdk$/
|
16
|
+
- !ruby/regexp /dos_mbr.img$/
|
17
|
+
- !ruby/regexp /test.rb$/
|
18
|
+
- !ruby/regexp /\/rdoc$/
|
19
|
+
- !ruby/regexp /\/examples$/
|
20
|
+
- !ruby/regexp /\/test$/
|
21
|
+
- !ruby/regexp /\/miqCryptInit.rb$/
|
22
|
+
- !ruby/regexp /\/VMwareWebService\/.*\.wsdl$/
|
@@ -0,0 +1,24 @@
|
|
1
|
+
---
|
2
|
+
-
|
3
|
+
:basedir: "../../.."
|
4
|
+
:todir: "/"
|
5
|
+
:include:
|
6
|
+
- vmdb
|
7
|
+
:exclude:
|
8
|
+
- !ruby/regexp /\/\.svn/
|
9
|
+
- !ruby/regexp /~$/
|
10
|
+
- !ruby/regexp /\/NTFSCPP/
|
11
|
+
- !ruby/regexp /\/TestVm/
|
12
|
+
- !ruby/regexp /\.c$/
|
13
|
+
- !ruby/regexp /\.h$/
|
14
|
+
- !ruby/regexp /\.o$/
|
15
|
+
- !ruby/regexp /\.vmdk$/
|
16
|
+
- !ruby/regexp /dos_mbr.img$/
|
17
|
+
- !ruby/regexp /test.rb$/
|
18
|
+
- !ruby/regexp /\/rdoc$/
|
19
|
+
- !ruby/regexp /\/examples$/
|
20
|
+
- !ruby/regexp /\/test$/
|
21
|
+
- !ruby/regexp /\/miqCryptInit.rb$/
|
22
|
+
- !ruby/regexp /\/VMwareWebService\/.*\.wsdl$/
|
23
|
+
:compress:
|
24
|
+
- !ruby/regexp /^vmdb\/.*$/
|
@@ -0,0 +1,22 @@
|
|
1
|
+
---
|
2
|
+
-
|
3
|
+
:basedir: "../../.."
|
4
|
+
:todir: "/"
|
5
|
+
:include:
|
6
|
+
- vmdb
|
7
|
+
:exclude:
|
8
|
+
- !ruby/regexp /\/\.svn/
|
9
|
+
- !ruby/regexp /~$/
|
10
|
+
- !ruby/regexp /\/NTFSCPP/
|
11
|
+
- !ruby/regexp /\/TestVm/
|
12
|
+
- !ruby/regexp /\.c$/
|
13
|
+
- !ruby/regexp /\.h$/
|
14
|
+
- !ruby/regexp /\.o$/
|
15
|
+
- !ruby/regexp /\.vmdk$/
|
16
|
+
- !ruby/regexp /dos_mbr.img$/
|
17
|
+
- !ruby/regexp /test.rb$/
|
18
|
+
- !ruby/regexp /\/rdoc$/
|
19
|
+
- !ruby/regexp /\/examples$/
|
20
|
+
- !ruby/regexp /\/test$/
|
21
|
+
- !ruby/regexp /\/miqCryptInit.rb$/
|
22
|
+
- !ruby/regexp /\/VMwareWebService\/.*\.wsdl$/
|
@@ -0,0 +1,126 @@
|
|
1
|
+
require 'log4r'
|
2
|
+
require 'ostruct'
|
3
|
+
require 'fs/MiqFS/MiqFS'
|
4
|
+
require 'fs/MiqFsUtil'
|
5
|
+
require 'fs/MetakitFS/MetakitFS'
|
6
|
+
require 'fs/MiqFS/modules/LocalFS'
|
7
|
+
|
8
|
+
SRC_DIR = "../../../.."
|
9
|
+
DST_DIR = "copy_dst"
|
10
|
+
MK_FILE = "mkfs"
|
11
|
+
|
12
|
+
#
|
13
|
+
# Formatter to output log messages to the console.
|
14
|
+
#
|
15
|
+
$stderr.sync = true
|
16
|
+
$stdout.sync = true
|
17
|
+
class ConsoleFormatter < Log4r::Formatter
|
18
|
+
def format(event)
|
19
|
+
t = Time.now
|
20
|
+
"#{t.hour}:#{t.min}:#{t.sec}: " + (event.data.kind_of?(String) ? event.data : event.data.inspect) + "\n"
|
21
|
+
end
|
22
|
+
end
|
23
|
+
$log = Log4r::Logger.new 'toplog'
|
24
|
+
Log4r::StderrOutputter.new('err_console', :level => Log4r::DEBUG, :formatter => ConsoleFormatter)
|
25
|
+
$log.add 'err_console'
|
26
|
+
|
27
|
+
#
|
28
|
+
# First, copy files from the local filesystem to another directory in the local filesystem.
|
29
|
+
#
|
30
|
+
|
31
|
+
fromFs = MiqFS.new(LocalFS, nil)
|
32
|
+
toFs = MiqFS.new(LocalFS, nil)
|
33
|
+
|
34
|
+
cf = MiqFsUtil.new(fromFs, toFs)
|
35
|
+
cf.verbose = true
|
36
|
+
|
37
|
+
#
|
38
|
+
# Make sure the destination directory exists and is empty.
|
39
|
+
#
|
40
|
+
toFs.rmBranch(DST_DIR) if toFs.fileDirectory?(DST_DIR)
|
41
|
+
toFs.dirMkdir(DST_DIR)
|
42
|
+
|
43
|
+
#
|
44
|
+
# Recursively copy the directory contents.
|
45
|
+
#
|
46
|
+
puts "Copying #{SRC_DIR} to #{DST_DIR}"
|
47
|
+
cf.copy(SRC_DIR, DST_DIR, true)
|
48
|
+
puts "copy complete"
|
49
|
+
|
50
|
+
#
|
51
|
+
# Compare the contents of the original directory to that of its copy.
|
52
|
+
# They should be the same.
|
53
|
+
#
|
54
|
+
dd = File.join(DST_DIR, File.basename(SRC_DIR))
|
55
|
+
puts "Comparing #{SRC_DIR} to #{dd}"
|
56
|
+
system("diff", "-qr", SRC_DIR, dd)
|
57
|
+
if $?.exitstatus != 0
|
58
|
+
puts "FAIL: Directory contents are not the same"
|
59
|
+
exit($?.exitstatus)
|
60
|
+
else
|
61
|
+
puts "SUCCESS: Directory contents match"
|
62
|
+
end
|
63
|
+
|
64
|
+
#
|
65
|
+
# Now, copy files from the local filesystem to a metakit filesystem.
|
66
|
+
#
|
67
|
+
|
68
|
+
#
|
69
|
+
# Create a new metakit filesystem.
|
70
|
+
#
|
71
|
+
File.delete(MK_FILE) if File.exist?(MK_FILE)
|
72
|
+
dobj = OpenStruct.new
|
73
|
+
dobj.mkfile = MK_FILE
|
74
|
+
dobj.create = true
|
75
|
+
toFs = MiqFS.new(MetakitFS, dobj)
|
76
|
+
|
77
|
+
#
|
78
|
+
# Set the new metakit filssystem as the destination of the copy.
|
79
|
+
#
|
80
|
+
cf.toFs = toFs
|
81
|
+
|
82
|
+
#
|
83
|
+
# Recursively copy the directory contents.
|
84
|
+
#
|
85
|
+
puts "Copying #{SRC_DIR} to / (on mkfs)"
|
86
|
+
cf.copy(SRC_DIR, "/", true)
|
87
|
+
puts "copy complete"
|
88
|
+
|
89
|
+
#
|
90
|
+
# Now, reverse the copy.
|
91
|
+
# Copy files out of the metakit FS to the local FS.
|
92
|
+
#
|
93
|
+
fromFs, toFs = toFs, fromFs
|
94
|
+
cf.toFs = toFs
|
95
|
+
cf.fromFs = fromFs
|
96
|
+
|
97
|
+
#
|
98
|
+
# Make sure the destination directory exists and is empty.
|
99
|
+
#
|
100
|
+
toFs.rmBranch(DST_DIR) if toFs.fileDirectory?(DST_DIR)
|
101
|
+
toFs.dirMkdir(DST_DIR)
|
102
|
+
|
103
|
+
puts
|
104
|
+
puts "Copying /vmdb (on mkfs) to #{DST_DIR}"
|
105
|
+
cf.copy("/vmdb", DST_DIR, true)
|
106
|
+
puts "copy complete"
|
107
|
+
|
108
|
+
#
|
109
|
+
# Compare the contents of the original directory to that of its copy.
|
110
|
+
# They should be the same.
|
111
|
+
#
|
112
|
+
puts
|
113
|
+
puts "Comparing #{SRC_DIR} to #{dd}"
|
114
|
+
system("diff", "-qr", SRC_DIR, dd)
|
115
|
+
if $?.exitstatus != 0
|
116
|
+
puts "FAIL: Directory contents are not the same"
|
117
|
+
exit($?.exitstatus)
|
118
|
+
else
|
119
|
+
puts "SUCCESS: Directory contents match"
|
120
|
+
end
|
121
|
+
|
122
|
+
#
|
123
|
+
# Clean up.
|
124
|
+
#
|
125
|
+
File.delete(MK_FILE) if File.exist?(MK_FILE)
|
126
|
+
toFs.rmBranch(DST_DIR) if toFs.fileDirectory?(DST_DIR)
|
@@ -0,0 +1,87 @@
|
|
1
|
+
require 'manageiq-gems-pending'
|
2
|
+
require 'log4r'
|
3
|
+
require 'ostruct'
|
4
|
+
require 'disk/MiqDisk'
|
5
|
+
require 'fs/MiqFS/MiqFS'
|
6
|
+
|
7
|
+
#
|
8
|
+
# Formatter to output log messages to the console.
|
9
|
+
#
|
10
|
+
class ConsoleFormatter < Log4r::Formatter
|
11
|
+
def format(event)
|
12
|
+
(event.data.kind_of?(String) ? event.data : event.data.inspect) + "\n"
|
13
|
+
end
|
14
|
+
end
|
15
|
+
$log = Log4r::Logger.new 'toplog'
|
16
|
+
$log.level = Log4r::DEBUG
|
17
|
+
Log4r::StderrOutputter.new('err_console', :formatter => ConsoleFormatter)
|
18
|
+
$log.add 'err_console'
|
19
|
+
|
20
|
+
#
|
21
|
+
# Path to RAW disk image.
|
22
|
+
#
|
23
|
+
VIRTUAL_DISK_FILE = "path to disk image file"
|
24
|
+
|
25
|
+
begin
|
26
|
+
diskInfo = OpenStruct.new
|
27
|
+
diskInfo.rawDisk = true # remove if image is not in RAW format.
|
28
|
+
diskInfo.fileName = VIRTUAL_DISK_FILE
|
29
|
+
|
30
|
+
disk = MiqDisk.getDisk(diskInfo)
|
31
|
+
raise "Failed to open disk: #{diskInfo.fileName}" unless disk
|
32
|
+
|
33
|
+
puts "Disk type: #{disk.diskType}"
|
34
|
+
puts "Disk partition type: #{disk.partType}"
|
35
|
+
puts "Disk block size: #{disk.blockSize}"
|
36
|
+
puts "Disk start LBA: #{disk.lbaStart}"
|
37
|
+
puts "Disk end LBA: #{disk.lbaEnd}"
|
38
|
+
puts "Disk start byte: #{disk.startByteAddr}"
|
39
|
+
puts "Disk end byte: #{disk.endByteAddr}"
|
40
|
+
|
41
|
+
parts = disk.getPartitions || []
|
42
|
+
|
43
|
+
i = 1
|
44
|
+
parts.each do |p|
|
45
|
+
puts "\nPartition #{i}:"
|
46
|
+
puts "\tDisk type: #{p.diskType}"
|
47
|
+
puts "\tPart partition type: #{p.partType}"
|
48
|
+
puts "\tPart block size: #{p.blockSize}"
|
49
|
+
puts "\tPart start LBA: #{p.lbaStart}"
|
50
|
+
puts "\tPart end LBA: #{p.lbaEnd}"
|
51
|
+
puts "\tPart start byte: #{p.startByteAddr}"
|
52
|
+
puts "\tPart end byte: #{p.endByteAddr}"
|
53
|
+
i += 1
|
54
|
+
end
|
55
|
+
|
56
|
+
target_partition = parts.first || disk
|
57
|
+
puts "\nTarget partition: #{target_partition.partNum}"
|
58
|
+
|
59
|
+
raise "No filesystem detected" unless (mfs = MiqFS.getFS(target_partition))
|
60
|
+
|
61
|
+
puts "FS type: #{mfs.fsType}"
|
62
|
+
puts "pwd = #{mfs.pwd}"
|
63
|
+
|
64
|
+
all_paths = mfs.find('/')
|
65
|
+
directories = all_paths.select { |p| mfs.fileDirectory?(p) }
|
66
|
+
files = all_paths.select { |p| mfs.fileFile?(p) }
|
67
|
+
sym_links = all_paths.select { |p| mfs.fileSymLink?(p) }
|
68
|
+
unclassified = all_paths - directories - files - sym_links
|
69
|
+
|
70
|
+
puts "files: #{files.length}"
|
71
|
+
puts "directories: #{directories.length}"
|
72
|
+
puts "sym_links: #{sym_links.length}"
|
73
|
+
puts "unclassified: #{unclassified.length}"
|
74
|
+
puts "total: #{files.length + directories.length + sym_links.length + unclassified.length}"
|
75
|
+
puts "all_paths: #{all_paths.length}"
|
76
|
+
|
77
|
+
unless unclassified.empty?
|
78
|
+
puts
|
79
|
+
puts "unclassified files:"
|
80
|
+
unclassified.each { |p| puts "\t#{p}" }
|
81
|
+
end
|
82
|
+
rescue => err
|
83
|
+
puts err.to_s
|
84
|
+
puts err.backtrace.join("\n")
|
85
|
+
ensure
|
86
|
+
disk.close if disk
|
87
|
+
end
|
@@ -0,0 +1,184 @@
|
|
1
|
+
require 'log4r'
|
2
|
+
require 'ostruct'
|
3
|
+
|
4
|
+
require 'fs/MiqFS/MiqFS'
|
5
|
+
require 'fs/MiqFsUtil'
|
6
|
+
require 'fs/MetakitFS/MetakitFS'
|
7
|
+
require 'fs/MiqFS/modules/LocalFS'
|
8
|
+
|
9
|
+
SRC_DIR = "../../../.."
|
10
|
+
DST_DIR = "copy_dst"
|
11
|
+
REF_DIR = "copy_dst_ref"
|
12
|
+
MK_FILE = "mkfs"
|
13
|
+
MK_FILE_NC = "mkfs_nc"
|
14
|
+
|
15
|
+
#
|
16
|
+
# Formatter to output log messages to the console.
|
17
|
+
#
|
18
|
+
$stderr.sync = true
|
19
|
+
$stdout.sync = true
|
20
|
+
class ConsoleFormatter < Log4r::Formatter
|
21
|
+
def format(event)
|
22
|
+
t = Time.now
|
23
|
+
"#{t.hour}:#{t.min}:#{t.sec}: " + (event.data.kind_of?(String) ? event.data : event.data.inspect) + "\n"
|
24
|
+
end
|
25
|
+
end
|
26
|
+
$log = Log4r::Logger.new 'toplog'
|
27
|
+
Log4r::StderrOutputter.new('err_console', :level => Log4r::DEBUG, :formatter => ConsoleFormatter)
|
28
|
+
$log.add 'err_console'
|
29
|
+
|
30
|
+
fromFs = MiqFS.new(LocalFS, nil)
|
31
|
+
toFs = MiqFS.new(LocalFS, nil)
|
32
|
+
|
33
|
+
cf = MiqFsUtil.new(fromFs, toFs, "collect_files_direct.yaml")
|
34
|
+
cf.verbose = true
|
35
|
+
|
36
|
+
#
|
37
|
+
# Make sure the destination directory exists and is empty.
|
38
|
+
#
|
39
|
+
toFs.rmBranch(REF_DIR) if toFs.fileDirectory?(REF_DIR)
|
40
|
+
toFs.dirMkdir(REF_DIR)
|
41
|
+
|
42
|
+
puts "*** Collecting files from #{SRC_DIR} to #{REF_DIR}"
|
43
|
+
cf.update
|
44
|
+
|
45
|
+
#
|
46
|
+
# Collect the same files from the same directory into a mkfs.
|
47
|
+
#
|
48
|
+
|
49
|
+
#
|
50
|
+
# Create a new metakit filesystem.
|
51
|
+
#
|
52
|
+
File.delete(MK_FILE_NC) if File.exist?(MK_FILE_NC)
|
53
|
+
dobj = OpenStruct.new
|
54
|
+
dobj.mkfile = MK_FILE_NC
|
55
|
+
dobj.create = true
|
56
|
+
mkFs_nc = MiqFS.new(MetakitFS, dobj)
|
57
|
+
|
58
|
+
#
|
59
|
+
# Set the new metakit filssystem as the destination of the copy.
|
60
|
+
#
|
61
|
+
cf.toFs = mkFs_nc
|
62
|
+
cf.updateSpec = "collect_files_in_nc.yaml"
|
63
|
+
|
64
|
+
puts
|
65
|
+
puts "*** Collecting files from #{SRC_DIR} to /vmdb (mkfs no compression)"
|
66
|
+
cf.update
|
67
|
+
|
68
|
+
#
|
69
|
+
# Now collect the same files from the same directory into a mkfs,
|
70
|
+
# compressing the files.
|
71
|
+
#
|
72
|
+
|
73
|
+
#
|
74
|
+
# Create a new metakit filesystem.
|
75
|
+
#
|
76
|
+
File.delete(MK_FILE) if File.exist?(MK_FILE)
|
77
|
+
dobj = OpenStruct.new
|
78
|
+
dobj.mkfile = MK_FILE
|
79
|
+
dobj.create = true
|
80
|
+
mkFs = MiqFS.new(MetakitFS, dobj)
|
81
|
+
|
82
|
+
#
|
83
|
+
# Set the new metakit filssystem as the destination of the copy.
|
84
|
+
#
|
85
|
+
cf.toFs = mkFs
|
86
|
+
cf.updateSpec = "collect_files_in.yaml"
|
87
|
+
|
88
|
+
puts
|
89
|
+
puts "*** Collecting files from #{SRC_DIR} to /vmdb (mkfs compressed)"
|
90
|
+
cf.update
|
91
|
+
|
92
|
+
mkFileNcSize = File.size(MK_FILE_NC).to_f
|
93
|
+
mkFileSize = File.size(MK_FILE).to_f
|
94
|
+
|
95
|
+
puts "Metakit file size: #{mkFileNcSize}, Compressed: #{mkFileSize}, #{(mkFileNcSize - mkFileSize) / mkFileNcSize * 100}% cpmpression"
|
96
|
+
|
97
|
+
#
|
98
|
+
# Now set up to reverse the copy, copying out of the mkfs to the local fs.
|
99
|
+
#
|
100
|
+
cf.toFs = cf.fromFs
|
101
|
+
cf.fromFs = mkFs_nc
|
102
|
+
cf.updateSpec = "collect_files_out.yaml"
|
103
|
+
|
104
|
+
#
|
105
|
+
# Make sure the destination directory exists and is empty.
|
106
|
+
#
|
107
|
+
cf.toFs.rmBranch(DST_DIR) if cf.toFs.fileDirectory?(DST_DIR)
|
108
|
+
cf.toFs.dirMkdir(DST_DIR)
|
109
|
+
|
110
|
+
puts
|
111
|
+
puts "*** Collecting files from /vmdb (mkfs not compressed) to #{DST_DIR}"
|
112
|
+
cf.update
|
113
|
+
|
114
|
+
#
|
115
|
+
# Compare the contents of the original directory to that of its copy.
|
116
|
+
# They should be the same.
|
117
|
+
#
|
118
|
+
puts "Comparing #{REF_DIR} to #{DST_DIR}"
|
119
|
+
system("diff", "-qr", REF_DIR, DST_DIR)
|
120
|
+
if $?.exitstatus != 0
|
121
|
+
puts "FAIL: Directory contents are not the same"
|
122
|
+
exit($?.exitstatus)
|
123
|
+
else
|
124
|
+
puts "SUCCESS: Directory contents match"
|
125
|
+
end
|
126
|
+
|
127
|
+
#
|
128
|
+
# Now, copy out of the compressed mkfs, and compare the same way.
|
129
|
+
#
|
130
|
+
|
131
|
+
cf.fromFs = mkFs
|
132
|
+
|
133
|
+
#
|
134
|
+
# Make sure the destination directory exists and is empty.
|
135
|
+
#
|
136
|
+
cf.toFs.rmBranch(DST_DIR) if cf.toFs.fileDirectory?(DST_DIR)
|
137
|
+
cf.toFs.dirMkdir(DST_DIR)
|
138
|
+
|
139
|
+
puts
|
140
|
+
puts "*** Collecting files from /vmdb (mkfs compressed) to #{DST_DIR}"
|
141
|
+
cf.update
|
142
|
+
|
143
|
+
#
|
144
|
+
# Compare the contents of the original directory to that of its copy.
|
145
|
+
# They should be the same.
|
146
|
+
#
|
147
|
+
puts "Comparing #{REF_DIR} to #{DST_DIR}"
|
148
|
+
system("diff", "-qr", REF_DIR, DST_DIR)
|
149
|
+
if $?.exitstatus != 0
|
150
|
+
puts "FAIL: Directory contents are not the same"
|
151
|
+
exit($?.exitstatus)
|
152
|
+
else
|
153
|
+
puts "SUCCESS: Directory contents match"
|
154
|
+
end
|
155
|
+
|
156
|
+
#
|
157
|
+
# Test the remove code.
|
158
|
+
#
|
159
|
+
cf.updateSpec = "collect_files_rm.yaml"
|
160
|
+
puts
|
161
|
+
puts "*** Removing files from #{DST_DIR}"
|
162
|
+
cf.update
|
163
|
+
|
164
|
+
#
|
165
|
+
# Compare the contents of the original directory to that of its copy.
|
166
|
+
# They should be different.
|
167
|
+
#
|
168
|
+
puts
|
169
|
+
puts "Comparing #{REF_DIR} to #{DST_DIR}"
|
170
|
+
system("diff", "-qr", REF_DIR, DST_DIR)
|
171
|
+
if $?.exitstatus == 0
|
172
|
+
puts "FAIL: Directory contents are the same"
|
173
|
+
exit($?.exitstatus)
|
174
|
+
else
|
175
|
+
puts "SUCCESS: Directory contents don't match"
|
176
|
+
end
|
177
|
+
|
178
|
+
#
|
179
|
+
# Clean up.
|
180
|
+
#
|
181
|
+
File.delete(MK_FILE) if File.exist?(MK_FILE)
|
182
|
+
File.delete(MK_FILE_NC) if File.exist?(MK_FILE_NC)
|
183
|
+
toFs.rmBranch(DST_DIR) if toFs.fileDirectory?(DST_DIR)
|
184
|
+
toFs.rmBranch(REF_DIR) if toFs.fileDirectory?(REF_DIR)
|