Unbewohnte
3 years ago
6 changed files with 92 additions and 107 deletions
@ -1,59 +0,0 @@
|
||||
package id3ed |
||||
|
||||
import ( |
||||
"fmt" |
||||
"io" |
||||
"os" |
||||
|
||||
v1 "github.com/Unbewohnte/id3ed/v1" |
||||
) |
||||
|
||||
type Tagger interface { |
||||
WriteToFile(*os.File) error |
||||
Version() int |
||||
} |
||||
|
||||
// Reads certain ID3 tags from io.ReadSeeker according to given version.
|
||||
// Wrapper function to v1|v2 package functions
|
||||
func ReadTags(rs io.ReadSeeker, version int) (Tagger, error) { |
||||
switch version { |
||||
|
||||
case 10: |
||||
// ID3v1
|
||||
t, err := v1.Getv1Tags(rs) |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
return t, nil |
||||
|
||||
case 11: |
||||
// ID3v1.1
|
||||
t, err := v1.Getv11Tags(rs) |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
return t, nil |
||||
|
||||
case 23: |
||||
// ID3v2.3
|
||||
return nil, fmt.Errorf("v2.3 is not supported") |
||||
|
||||
case 24: |
||||
// ID3v2.4
|
||||
return nil, fmt.Errorf("v2.4 is not supported") |
||||
} |
||||
|
||||
return nil, fmt.Errorf("invalid version or not supported") |
||||
} |
||||
|
||||
// DOESN`T work for some reason !? err is coming from f.Seek(), but it`s completely fine
|
||||
// when run directly from v1.WriteToFile() function.
|
||||
// Writes tags to file.
|
||||
func WriteTags(dstf *os.File, t Tagger) error { |
||||
err := t.WriteToFile(dstf) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
|
||||
return nil |
||||
} |
@ -1,48 +0,0 @@
|
||||
package id3ed |
||||
|
||||
import ( |
||||
"os" |
||||
"path/filepath" |
||||
"testing" |
||||
) |
||||
|
||||
var TESTDATAPATH string = filepath.Join("testData") |
||||
|
||||
func TestReadTags(t *testing.T) { |
||||
f, err := os.OpenFile(filepath.Join(TESTDATAPATH, "testreadv1.mp3"), os.O_RDONLY, os.ModePerm) |
||||
if err != nil { |
||||
t.Errorf("%s", err) |
||||
} |
||||
|
||||
_, err = ReadTags(f, 11) |
||||
if err != nil { |
||||
t.Errorf("ReadTags failed: %s", err) |
||||
} |
||||
|
||||
_, err = ReadTags(f, 10) |
||||
if err != nil { |
||||
t.Errorf("ReadTags failed: %s", err) |
||||
} |
||||
} |
||||
|
||||
// func TestWriteTags(t *testing.T) {
|
||||
// f, err := os.OpenFile(filepath.Join(TESTDATAPATH, "testreadv1.mp3"), os.O_RDONLY, os.ModePerm)
|
||||
// if err != nil {
|
||||
// t.Errorf("%s", err)
|
||||
// }
|
||||
|
||||
// tagger, err := ReadTags(f, 11)
|
||||
// if err != nil {
|
||||
// t.Errorf("%s", err)
|
||||
// }
|
||||
|
||||
// f2, err := os.OpenFile(filepath.Join(TESTDATAPATH, "testWriteTags.mp3"), os.O_CREATE|os.O_RDWR|os.O_TRUNC, os.ModePerm)
|
||||
// if err != nil {
|
||||
// t.Errorf("%s", err)
|
||||
// }
|
||||
|
||||
// err = WriteTags(f2, tagger)
|
||||
// if err != nil {
|
||||
// t.Errorf("WriteTags failed: %s", err)
|
||||
// }
|
||||
// }
|
Binary file not shown.
@ -0,0 +1,60 @@
|
||||
package util |
||||
|
||||
import ( |
||||
"bytes" |
||||
"testing" |
||||
) |
||||
|
||||
func TestRead(t *testing.T) { |
||||
testBuffer := new(bytes.Buffer) |
||||
|
||||
_, err := testBuffer.WriteString("Writing some data here. ᗜˬᗜ") |
||||
if err != nil { |
||||
t.Errorf("%s", err) |
||||
} |
||||
|
||||
buffLen := testBuffer.Len() |
||||
buffBytes := testBuffer.Bytes() |
||||
|
||||
read, err := Read(testBuffer, uint64(buffLen)) |
||||
if err != nil { |
||||
t.Errorf("Read failed: %s", err) |
||||
} |
||||
|
||||
if int(len(read)) != int(buffLen) { |
||||
t.Errorf("Read failed: expected length %d; got %d", buffLen, len(read)) |
||||
} |
||||
|
||||
for index, b := range read { |
||||
if buffBytes[index] != b { |
||||
t.Errorf("Read failed: expected byte %v; got %v at index %d", buffBytes[index], b, index) |
||||
} |
||||
} |
||||
} |
||||
|
||||
func TestReadToString(t *testing.T) { |
||||
testBuffer := new(bytes.Buffer) |
||||
|
||||
_, err := testBuffer.WriteString("This is literally the same as before. ᗜˬᗜ") |
||||
if err != nil { |
||||
t.Errorf("%s", err) |
||||
} |
||||
|
||||
buffLen := testBuffer.Len() |
||||
buffBytes := testBuffer.Bytes() |
||||
|
||||
read, err := Read(testBuffer, uint64(buffLen)) |
||||
if err != nil { |
||||
t.Errorf("Read failed: %s", err) |
||||
} |
||||
|
||||
if int(len(read)) != int(buffLen) { |
||||
t.Errorf("Read failed: expected length %d; got %d", buffLen, len(read)) |
||||
} |
||||
|
||||
for index, b := range read { |
||||
if buffBytes[index] != b { |
||||
t.Errorf("Read failed: expected byte %v; got %v at index %d", buffBytes[index], b, index) |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,32 @@
|
||||
package util |
||||
|
||||
import ( |
||||
"bytes" |
||||
"testing" |
||||
) |
||||
|
||||
func TestWriteToExtent(t *testing.T) { |
||||
testBuff := new(bytes.Buffer) |
||||
|
||||
testData := []byte("some data here") |
||||
|
||||
err := WriteToExtent(testBuff, testData, len(testData)+50) |
||||
if err != nil { |
||||
t.Errorf("WriteToExtent failed: %s", err) |
||||
} |
||||
|
||||
if testBuff.Len() != len(testData)+50 { |
||||
t.Errorf("WriteToExtent failed: expected length %d; got %d", len(testData)+50, testBuff.Len()) |
||||
} |
||||
|
||||
nullByteCounter := 0 |
||||
for _, b := range testBuff.Bytes() { |
||||
if b == 0 { |
||||
nullByteCounter++ |
||||
} |
||||
} |
||||
|
||||
if nullByteCounter != 50 { |
||||
t.Errorf("WriteToExtent failed: expected null bytes %d; got %d", 50, nullByteCounter) |
||||
} |
||||
} |
Loading…
Reference in new issue