summaryrefslogtreecommitdiff
path: root/tests/reverse/correctness_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'tests/reverse/correctness_test.go')
-rw-r--r--tests/reverse/correctness_test.go16
1 files changed, 16 insertions, 0 deletions
diff --git a/tests/reverse/correctness_test.go b/tests/reverse/correctness_test.go
index 930048f..b335456 100644
--- a/tests/reverse/correctness_test.go
+++ b/tests/reverse/correctness_test.go
@@ -298,6 +298,10 @@ func TestSeekData(t *testing.T) {
// gocryptfs.longname.*.name of hardlinked files should not appear hardlinked (as the
// contents are different).
//
+// This means that
+// 1) They have a different NodeID, hence the kernel knows it's different files
+// 2) They have a different inode number, hence userspace knows they are not hard-linked.
+//
// https://github.com/rfjakob/gocryptfs/issues/802
func TestHardlinkedLongname(t *testing.T) {
if plaintextnames {
@@ -335,4 +339,16 @@ func TestHardlinkedLongname(t *testing.T) {
if test_helpers.Md5fn(matches[0]) == test_helpers.Md5fn(matches[1]) {
t.Errorf("Files %q are identical - that's wrong!", matches)
}
+
+ var st0 syscall.Stat_t
+ if err := syscall.Stat(matches[0], &st0); err != nil {
+ t.Fatal(err)
+ }
+ var st1 syscall.Stat_t
+ if err := syscall.Stat(matches[1], &st1); err != nil {
+ t.Fatal(err)
+ }
+ if st0.Ino == st1.Ino {
+ t.Errorf("Files %q have the same inode number - that's wrong!", matches)
+ }
}