diff mbox

[v4] btrfs-progs: misc-tests: Superblock corruption and recovery using backup

Message ID 20170415101308.GA7614@giis.co.in (mailing list archive)
State New, archived
Headers show

Commit Message

Lakshmipathi.G April 15, 2017, 10:13 a.m. UTC
Signed-off-by: Lakshmipathi.G <Lakshmipathi.G@giis.co.in>
---
 .../020-fix-superblock-corruption/test.sh          | 35 ++++++++++++++++++++++
 1 file changed, 35 insertions(+)
 create mode 100755 tests/misc-tests/020-fix-superblock-corruption/test.sh

Comments

David Sterba April 19, 2017, 5:06 p.m. UTC | #1
On Sat, Apr 15, 2017 at 03:43:08PM +0530, Lakshmipathi.G wrote:
> Signed-off-by: Lakshmipathi.G <Lakshmipathi.G@giis.co.in>

Applied, thanks.
--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/tests/misc-tests/020-fix-superblock-corruption/test.sh b/tests/misc-tests/020-fix-superblock-corruption/test.sh
new file mode 100755
index 0000000..0faebad
--- /dev/null
+++ b/tests/misc-tests/020-fix-superblock-corruption/test.sh
@@ -0,0 +1,35 @@ 
+#!/bin/bash
+#
+# Corrupt primary superblock and restore it using backup superblock.
+#
+
+source $TOP/tests/common
+
+check_prereq btrfs-select-super
+check_prereq btrfs
+
+setup_root_helper
+prepare_test_dev
+
+FIRST_SUPERBLOCK_OFFSET=65536
+
+test_superblock_restore()
+{
+	run_check $SUDO_HELPER "$TOP/mkfs.btrfs" -f "$TEST_DEV"
+
+	# Corrupt superblock checksum
+        run_check $SUDO_HELPER dd if=/dev/zero of="$TEST_DEV" \
+	seek="$FIRST_SUPERBLOCK_OFFSET" bs=1 count=4 conv=notrunc
+
+	# Run btrfs check to detect corruption
+	run_mayfail "$TOP/btrfs" check "$TEST_DEV" && \
+		_fail "btrfs check should detect corruption"
+
+	# Copy backup superblock to primary
+	run_check "$TOP/btrfs-select-super" -s 1 "$TEST_DEV"
+
+	#Performing btrfs check
+	run_check "$TOP/btrfs" check "$TEST_DEV"
+}
+
+test_superblock_restore