X-Git-Url: https://git.r.bdr.sh/rbdr/mobius/blobdiff_plain/bb7fe19f7e331f0e8c79f4da61543981acd36422..12cae6a70ba4a908f4d47e7b7d0c03a6f2c6ed6e:/hotline/flattened_file_object_test.go?ds=sidebyside diff --git a/hotline/flattened_file_object_test.go b/hotline/flattened_file_object_test.go index 5bbaf1d..4b3fdf6 100644 --- a/hotline/flattened_file_object_test.go +++ b/hotline/flattened_file_object_test.go @@ -1,26 +1,12 @@ package hotline import ( - "bytes" - "encoding/hex" "fmt" "github.com/stretchr/testify/assert" "os" "testing" ) -func TestReadFlattenedFileObject(t *testing.T) { - testData, _ := hex.DecodeString("46494c500001000000000000000000000000000000000002494e464f000000000000000000000052414d414354455854747478740000000000000100000000000000000000000000000000000000000000000000000000000000000007700000ba74247307700000ba74247300000008746573742e74787400004441544100000000000000000000000474657374") - - ffo := ReadFlattenedFileObject(testData) - - format := ffo.FlatFileHeader.Format[:] - want := []byte("FILP") - if !bytes.Equal(format, want) { - t.Errorf("ReadFlattenedFileObject() = %q, want %q", format, want) - } -} - func TestNewFlattenedFileObject(t *testing.T) { type args struct { fileRoot string @@ -43,12 +29,12 @@ func TestNewFlattenedFileObject(t *testing.T) { want: &flattenedFileObject{ FlatFileHeader: NewFlatFileHeader(), FlatFileInformationForkHeader: FlatFileInformationForkHeader{}, - FlatFileInformationFork: NewFlatFileInformationFork("testfile.txt"), + FlatFileInformationFork: NewFlatFileInformationFork("testfile.txt", make([]byte, 8), "", ""), FlatFileDataForkHeader: FlatFileDataForkHeader{ - ForkType: []byte("DATA"), - CompressionType: []byte{0, 0, 0, 0}, - RSVD: []byte{0, 0, 0, 0}, - DataSize: []byte{0x00, 0x00, 0x00, 0x17}, + ForkType: [4]byte{0x4d, 0x41, 0x43, 0x52}, // DATA + CompressionType: [4]byte{0, 0, 0, 0}, + RSVD: [4]byte{0, 0, 0, 0}, + DataSize: [4]byte{0x00, 0x00, 0x00, 0x17}, }, FileData: nil, }, @@ -66,75 +52,52 @@ func TestNewFlattenedFileObject(t *testing.T) { } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { - got, err := NewFlattenedFileObject(tt.args.fileRoot, tt.args.filePath, tt.args.fileName) - if !tt.wantErr(t, err, fmt.Sprintf("NewFlattenedFileObject(%v, %v, %v)", tt.args.fileRoot, tt.args.filePath, tt.args.fileName)) { + got, err := NewFlattenedFileObject(tt.args.fileRoot, tt.args.filePath, tt.args.fileName, 0) + if tt.wantErr(t, err, fmt.Sprintf("NewFlattenedFileObject(%v, %v, %v)", tt.args.fileRoot, tt.args.filePath, tt.args.fileName)) { return } + + // Clear the file timestamp fields to work around problems running the tests in multiple timezones + // TODO: revisit how to test this by mocking the stat calls + got.FlatFileInformationFork.CreateDate = make([]byte, 8) + got.FlatFileInformationFork.ModifyDate = make([]byte, 8) assert.Equalf(t, tt.want, got, "NewFlattenedFileObject(%v, %v, %v)", tt.args.fileRoot, tt.args.filePath, tt.args.fileName) }) } } -func Test_flattenedFileObject_BinaryMarshal(t *testing.T) { - - testData, _ := hex.DecodeString("46494c500001000000000000000000000000000000000002494e464f000000000000000000000052414d414354455854747478740000000000000100000000000000000000000000000000000000000000000000000000000000000007700000ba74247307700000ba74247300000008746573742e74787400004441544100000000000000000000000474657374") - testFile := ReadFlattenedFileObject(testData) - testFile.FlatFileInformationFork.Comment = []byte("test!") - testFile.FlatFileInformationFork.CommentSize = []byte{0x00, 0x05} - - type fields struct { - FlatFileHeader FlatFileHeader - FlatFileInformationForkHeader FlatFileInformationForkHeader - FlatFileInformationFork FlatFileInformationFork - FlatFileDataForkHeader FlatFileDataForkHeader - FileData []byte +func TestFlatFileInformationFork_UnmarshalBinary(t *testing.T) { + type args struct { + b []byte } tests := []struct { - name string - fields fields - want []byte + name string + args args + wantErr assert.ErrorAssertionFunc }{ { - name: "with a valid file", - fields: fields{ - FlatFileHeader: testFile.FlatFileHeader, - FlatFileInformationForkHeader: testFile.FlatFileInformationForkHeader, - FlatFileInformationFork: testFile.FlatFileInformationFork, - FlatFileDataForkHeader: testFile.FlatFileDataForkHeader, - FileData: testFile.FileData, + name: "when zero length comment size is omitted (Nostalgia client behavior)", + args: args{ + b: []byte{ + 0x41, 0x4d, 0x41, 0x43, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x09, 0x62, 0x65, 0x61, 0x72, 0x2e, 0x74, 0x69, 0x66, 0x66, + }, }, - want: []byte{ - 0x46, 0x49, 0x4c, 0x50, 0x00, 0x01, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, - 0x49, 0x4e, 0x46, 0x4f, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x57, - 0x41, 0x4d, 0x41, 0x43, 0x54, 0x45, 0x58, 0x54, - 0x74, 0x74, 0x78, 0x74, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x07, 0x70, 0x00, 0x00, - 0xba, 0x74, 0x24, 0x73, 0x07, 0x70, 0x00, 0x00, - 0xba, 0x74, 0x24, 0x73, 0x00, 0x00, 0x00, 0x08, - 0x74, 0x65, 0x73, 0x74, 0x2e, 0x74, 0x78, 0x74, - 0x00, 0x05, 0x74, 0x65, 0x73, 0x74, 0x21, 0x44, - 0x41, 0x54, 0x41, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x04, + wantErr: assert.NoError, + }, + { + name: "when zero length comment size is included", + args: args{ + b: []byte{ + 0x41, 0x4d, 0x41, 0x43, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x3f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x09, 0x62, 0x65, 0x61, 0x72, 0x2e, 0x74, 0x69, 0x66, 0x66, 0x00, 0x00, + }, }, + wantErr: assert.NoError, }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { - f := flattenedFileObject{ - FlatFileHeader: tt.fields.FlatFileHeader, - FlatFileInformationForkHeader: tt.fields.FlatFileInformationForkHeader, - FlatFileInformationFork: tt.fields.FlatFileInformationFork, - FlatFileDataForkHeader: tt.fields.FlatFileDataForkHeader, - FileData: tt.fields.FileData, - } - assert.Equalf(t, tt.want, f.BinaryMarshal(), "BinaryMarshal()") + ffif := &FlatFileInformationFork{} + tt.wantErr(t, ffif.UnmarshalBinary(tt.args.b), fmt.Sprintf("UnmarshalBinary(%v)", tt.args.b)) }) } }