package mirclike_test import ( "strings" "testing" "time" "github.com/stretchr/testify/assert" "git.aiterp.net/rpdata/api/internal/importers/mirclike" "git.aiterp.net/rpdata/api/models" ) var testLog = strings.Join([]string{ "[11:21] * Va`ynna_Atana returns to the apartment at the end of another long day. She hangs up her jacket and a green scarf next to the door before going straight to the bathroom; she leaves the door open, though. She walked home with Uvena this time, but the two parted ways downstairs.", "", "[11:21] <=Scene=> The weather outside is not pleasant in the slightest. The storm is still going on, visibility is reduced and the worst gusts of wind can be felt inside the apartment as a faint shudder. ", "", "[11:", " [11:27] Stuff and things.", }, "\r\n") var testLogPosts = []models.Post{ { ID: "UNASSIGNED", LogID: "UNASSIGNED", Time: parseDate(nil, "2018-05-11 11:21:00"), Kind: "action", Nick: "Va`ynna_Atana", Position: 1, Text: "returns to the apartment at the end of another long day. She hangs up her jacket and a green scarf next to the door before going straight to the bathroom; she leaves the door open, though. She walked home with Uvena this time, but the two parted ways downstairs.", }, { ID: "UNASSIGNED", LogID: "UNASSIGNED", Time: parseDate(nil, "2018-05-11 11:21:00"), Kind: "scene", Nick: "=Scene=", Position: 2, Text: "The weather outside is not pleasant in the slightest. The storm is still going on, visibility is reduced and the worst gusts of wind can be felt inside the apartment as a faint shudder.", }, { ID: "UNASSIGNED", LogID: "UNASSIGNED", Time: parseDate(nil, "2018-05-11 11:27:00"), Kind: "text", Nick: "Test", Position: 3, Text: "Stuff and things.", }, } func TestParseLog(t *testing.T) { log, posts, err := mirclike.ParseLog(testLog, parseDate(t, "2018-05-11 00:00:00"), false) if err != nil { t.Fatal("ParseLog", err) } assert.Equal(t, testLogPosts, posts) assert.Equal(t, posts[0].Time, log.Date, "Log's date should be the first post's.") } func TestParseLogErrors(t *testing.T) { _, _, err1 := mirclike.ParseLog("\n\n\n\n\n \n\t\r\n", time.Time{}, false) _, _, err2 := mirclike.ParseLog("\n\n\n\n\n[14:57]* Stuff \n\t\r\n", time.Time{}, true) assert.Equal(t, mirclike.ErrEmptyLog, err1) assert.Equal(t, mirclike.ErrNotPost, err2) }