This commit is contained in:
2025-09-15 07:40:33 +02:00
parent bea94be43c
commit 006dab5905
2 changed files with 375 additions and 2 deletions

View File

@@ -62,7 +62,7 @@ pub fn (mut self DBFsBlobMembership) set(o FsBlobMembership) !string {
// Validate that all filesystems exist
for fs_id in o.fsid {
fs_exists := self.factory.fs_file.exist(fs_id)!
fs_exists := self.factory.fs.exist(fs_id)!
if !fs_exists {
return error('Filesystem with ID ${fs_id} does not exist')
}
@@ -106,7 +106,7 @@ pub fn (mut self DBFsBlobMembership) get(hash string) !FsBlobMembership {
// Add a filesystem to an existing blob membership
pub fn (mut self DBFsBlobMembership) add_filesystem(hash string, fs_id u32) !string {
// Validate filesystem exists
fs_exists := self.factory.fs_file.exist(fs_id)!
fs_exists := self.factory.fs.exist(fs_id)!
if !fs_exists {
return error('Filesystem with ID ${fs_id} does not exist')
}

View File

@@ -0,0 +1,373 @@
module herofs
import freeflowuniverse.herolib.hero.db
fn test_basic() {
println('Testing FsBlobMembership functionality...')
// Initialize the HeroFS factory
mut fs_factory := new()!
println('HeroFS factory initialized')
// Create a new filesystem (required for FsBlobMembership validation)
mut my_fs := fs_factory.fs.new(
name: 'test_filesystem'
description: 'Filesystem for testing FsBlobMembership functionality'
quota_bytes: 1024 * 1024 * 1024 // 1GB quota
)!
fs_id := fs_factory.fs.set(my_fs)!
println('Created test filesystem with ID: ${fs_id}')
// Create root directory for the filesystem
mut root_dir := fs_factory.fs_dir.new(
name: 'root'
fs_id: fs_id
parent_id: 0 // Root has no parent
description: 'Root directory for testing'
)!
root_dir_id := fs_factory.fs_dir.set(root_dir)!
// Update the filesystem with the root directory ID
my_fs.root_dir_id = root_dir_id
fs_factory.fs.set(my_fs)!
// Create test blob for membership
test_data := 'This is test content for blob membership'.bytes()
mut test_blob := fs_factory.fs_blob.new(data: test_data)!
blob_id := fs_factory.fs_blob.set(test_blob)!
println('Created test blob with ID: ${blob_id}')
// Create test file to get a valid fsid (file ID) for membership
mut test_file := fs_factory.fs_file.new(
name: 'test_file.txt'
fs_id: fs_id
directories: [root_dir_id]
blobs: [blob_id]
description: 'Test file for blob membership'
mime_type: .txt
)!
file_id := fs_factory.fs_file.set(test_file)!
println('Created test file with ID: ${file_id}')
// Create test blob membership
mut test_membership := fs_factory.fs_blob_membership.new(
hash: test_blob.hash
fsid: [fs_id] // Use filesystem ID
blobid: blob_id
)!
// Save the test membership
membership_hash := fs_factory.fs_blob_membership.set(test_membership)!
println('Created test blob membership with hash: ${membership_hash}')
// Test loading membership by hash
println('\nTesting blob membership loading...')
loaded_membership := fs_factory.fs_blob_membership.get(membership_hash)!
assert loaded_membership.hash == test_membership.hash
assert loaded_membership.fsid == test_membership.fsid
assert loaded_membership.blobid == test_membership.blobid
println(' Loaded blob membership: ${loaded_membership.hash} (Blob ID: ${loaded_membership.blobid})')
// Verify that loaded membership matches the original one
println('\nVerifying data integrity...')
assert loaded_membership.hash == test_blob.hash
println(' Blob membership data integrity check passed')
// Test exist method
println('\nTesting blob membership existence checks...')
mut exists := fs_factory.fs_blob_membership.exist(membership_hash)!
assert exists == true
println(' Blob membership exists: ${exists}')
// Test with non-existent hash
non_existent_hash := '0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef'
exists = fs_factory.fs_blob_membership.exist(non_existent_hash)!
assert exists == false
println(' Non-existent blob membership exists: ${exists}')
println('\nFsBlobMembership basic test completed successfully!')
}
fn test_filesystem_operations() {
println('\nTesting FsBlobMembership filesystem operations...')
// Initialize the HeroFS factory
mut fs_factory := new()!
// Create filesystems for testing
mut fs1 := fs_factory.fs.new(
name: 'test_filesystem_1'
description: 'First filesystem for testing'
quota_bytes: 1024 * 1024 * 1024 // 1GB quota
)!
fs1_id := fs_factory.fs.set(fs1)!
mut fs2 := fs_factory.fs.new(
name: 'test_filesystem_2'
description: 'Second filesystem for testing'
quota_bytes: 1024 * 1024 * 1024 // 1GB quota
)!
fs2_id := fs_factory.fs.set(fs2)!
// Create root directories for the filesystems
mut root_dir1 := fs_factory.fs_dir.new(
name: 'root'
fs_id: fs1_id
parent_id: 0 // Root has no parent
description: 'Root directory for testing'
)!
root_dir1_id := fs_factory.fs_dir.set(root_dir1)!
// Update the filesystems with the root directory IDs
fs1.root_dir_id = root_dir1_id
fs_factory.fs.set(fs1)!
mut root_dir2 := fs_factory.fs_dir.new(
name: 'root'
fs_id: fs2_id
parent_id: 0 // Root has no parent
description: 'Root directory for testing'
)!
root_dir2_id := fs_factory.fs_dir.set(root_dir2)!
// Update the filesystems with the root directory IDs
fs2.root_dir_id = root_dir2_id
fs_factory.fs.set(fs2)!
// Create test blob
test_data := 'This is test content for filesystem operations'.bytes()
mut test_blob := fs_factory.fs_blob.new(data: test_data)!
blob_id := fs_factory.fs_blob.set(test_blob)!
// Create test files to get valid fsid (file IDs) for membership
mut test_file1 := fs_factory.fs_file.new(
name: 'test_file1.txt'
fs_id: fs1_id
directories: [root_dir1_id]
blobs: [blob_id]
description: 'Test file 1 for blob membership'
mime_type: .txt
)!
file1_id := fs_factory.fs_file.set(test_file1)!
println('Created test file 1 with ID: ${file1_id}')
mut test_file2 := fs_factory.fs_file.new(
name: 'test_file2.txt'
fs_id: fs2_id
directories: [root_dir2_id]
blobs: [blob_id]
description: 'Test file 2 for blob membership'
mime_type: .txt
)!
file2_id := fs_factory.fs_file.set(test_file2)!
println('Created test file 2 with ID: ${file2_id}')
// Create blob membership with first filesystem
mut membership := fs_factory.fs_blob_membership.new(
hash: test_blob.hash
fsid: [fs1_id] // Use filesystem ID
blobid: blob_id
)!
membership_hash := fs_factory.fs_blob_membership.set(membership)!
println('Created blob membership with filesystem 1: ${membership_hash}')
// Test adding a filesystem to membership
println('Testing add_filesystem operation...')
// Add second filesystem
updated_hash := fs_factory.fs_blob_membership.add_filesystem(membership_hash, fs2_id)!
updated_membership := fs_factory.fs_blob_membership.get(updated_hash)!
// Verify both filesystems are in the list
assert updated_membership.fsid.len == 2
assert fs1_id in updated_membership.fsid
assert fs2_id in updated_membership.fsid
println(' Added filesystem 2 to blob membership')
// Test removing a filesystem from membership
println('Testing remove_filesystem operation...')
// Remove first filesystem
mut updated_hash2 := fs_factory.fs_blob_membership.remove_filesystem(membership_hash,
fs1_id)!
mut updated_membership2 := fs_factory.fs_blob_membership.get(updated_hash2)!
// Verify only second filesystem is in the list
assert updated_membership2.fsid.len == 1
assert updated_membership2.fsid[0] == fs2_id
println(' Removed filesystem 1 from blob membership')
// Test removing the last filesystem (should delete the membership)
mut updated_hash3 := fs_factory.fs_blob_membership.remove_filesystem(membership_hash,
fs2_id)!
// Verify membership no longer exists
exists := fs_factory.fs_blob_membership.exist(membership_hash)!
assert exists == false
println(' Removed last filesystem and deleted blob membership')
println('FsBlobMembership filesystem operations test completed successfully!')
}
fn test_validation() {
println('\nTesting FsBlobMembership validation...')
// Initialize the HeroFS factory
mut fs_factory := new()!
// Create a filesystem for validation tests
mut my_fs := fs_factory.fs.new(
name: 'validation_filesystem'
description: 'Filesystem for validation tests'
quota_bytes: 1024 * 1024 * 1024 // 1GB quota
)!
fs_id := fs_factory.fs.set(my_fs)!
// Test setting membership with non-existent blob (should fail)
println('Testing membership set with non-existent blob...')
// Create a membership with a non-existent blob ID
mut test_membership := fs_factory.fs_blob_membership.new(
hash: '0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef'
fsid: [fs_id]
blobid: 999999 // Non-existent blob ID
)!
// Try to save it, which should fail
validation_result_hash := fs_factory.fs_blob_membership.set(test_membership) or {
println(' Membership set correctly failed with non-existent blob')
return
}
panic('Validation should have failed for non-existent blob')
// Test setting membership with non-existent filesystem (should fail)
println('Testing membership set with non-existent filesystem...')
// Create a test blob
test_data := 'This is test content for validation'.bytes()
mut test_blob := fs_factory.fs_blob.new(data: test_data)!
blob_id := fs_factory.fs_blob.set(test_blob)!
// Create a membership with a non-existent filesystem ID
mut test_membership2 := fs_factory.fs_blob_membership.new(
hash: test_blob.hash
fsid: [u32(999999)] // Non-existent filesystem ID
blobid: blob_id
)!
// Try to save it, which should fail
validation_result_hash2 := fs_factory.fs_blob_membership.set(test_membership2) or {
println(' Membership set correctly failed with non-existent filesystem')
return
}
panic('Validation should have failed for non-existent filesystem')
println('FsBlobMembership validation test completed successfully!')
}
fn test_list_by_prefix() {
println('\nTesting FsBlobMembership list by prefix...')
// Initialize the HeroFS factory
mut fs_factory := new()!
// Create a filesystem
mut my_fs := fs_factory.fs.new(
name: 'list_test_filesystem'
description: 'Filesystem for list testing'
quota_bytes: 1024 * 1024 * 1024 // 1GB quota
)!
fs_id := fs_factory.fs.set(my_fs)!
// Create root directory for the filesystem
mut root_dir := fs_factory.fs_dir.new(
name: 'root'
fs_id: fs_id
parent_id: 0 // Root has no parent
description: 'Root directory for testing'
)!
root_dir_id := fs_factory.fs_dir.set(root_dir)!
// Update the filesystem with the root directory ID
my_fs.root_dir_id = root_dir_id
fs_factory.fs.set(my_fs)!
// Create multiple test blobs
test_data1 := 'This is test content 1'.bytes()
test_data2 := 'This is test content 2'.bytes()
test_data3 := 'This is test content 3'.bytes()
mut blob1 := fs_factory.fs_blob.new(data: test_data1)!
mut blob2 := fs_factory.fs_blob.new(data: test_data2)!
mut blob3 := fs_factory.fs_blob.new(data: test_data3)!
blob1_id := fs_factory.fs_blob.set(blob1)!
blob2_id := fs_factory.fs_blob.set(blob2)!
blob3_id := fs_factory.fs_blob.set(blob3)!
// Create test files to get valid fsid (file IDs) for membership
mut test_file := fs_factory.fs_file.new(
name: 'test_file.txt'
fs_id: fs_id
directories: [root_dir_id]
blobs: [blob1_id]
description: 'Test file for blob membership'
mime_type: .txt
)!
file_id := fs_factory.fs_file.set(test_file)!
println('Created test file with ID: ${file_id}')
// Create memberships with similar hashes (first 16 characters)
mut membership1 := fs_factory.fs_blob_membership.new(
hash: blob1.hash
fsid: [fs_id] // Use filesystem ID
blobid: blob1_id
)!
membership1_hash := fs_factory.fs_blob_membership.set(membership1)!
mut membership2 := fs_factory.fs_blob_membership.new(
hash: blob2.hash
fsid: [fs_id] // Use filesystem ID
blobid: blob2_id
)!
membership2_hash := fs_factory.fs_blob_membership.set(membership2)!
mut membership3 := fs_factory.fs_blob_membership.new(
hash: blob3.hash
fsid: [fs_id] // Use filesystem ID
blobid: blob3_id
)!
membership3_hash := fs_factory.fs_blob_membership.set(membership3)!
println('Created test memberships:')
println('- Membership 1 hash: ${membership1_hash}')
println('- Membership 2 hash: ${membership2_hash}')
println('- Membership 3 hash: ${membership3_hash}')
// Test listing by hash prefix
// Use first 16 characters of the first hash as prefix
prefix := membership1_hash[..16]
mut memberships := fs_factory.fs_blob_membership.list(prefix)!
// Should find at least one membership (membership1)
assert memberships.len >= 1
mut found := false
for membership in memberships {
if membership.hash == membership1_hash {
found = true
break
}
}
assert found == true
println(' Listed blob memberships by prefix: ${prefix}')
// Test with non-existent prefix
non_existent_prefix := '0000000000000000'
mut empty_memberships := fs_factory.fs_blob_membership.list(non_existent_prefix)!
assert empty_memberships.len == 0
println(' List with non-existent prefix returns empty array')
println('FsBlobMembership list by prefix test completed successfully!')
}