diff options
Diffstat (limited to '')
-rw-r--r-- | pkg/datamaps/writer_test.go | 110 |
1 files changed, 106 insertions, 4 deletions
diff --git a/pkg/datamaps/writer_test.go b/pkg/datamaps/writer_test.go index 92af664..d4c5fcf 100644 --- a/pkg/datamaps/writer_test.go +++ b/pkg/datamaps/writer_test.go @@ -1,9 +1,18 @@ package datamaps import ( + "fmt" "os" - "path/filepath" + "os/exec" + "strings" "testing" + + "github.com/tealeg/xlsx/v3" +) + +var ( + fileToColIdx = make(map[string]int) + filesInMaster []string ) func TestWriteMaster(t *testing.T) { @@ -28,9 +37,9 @@ func TestWriteMaster(t *testing.T) { XLSXPath: "./testdata/", } - defer func() { - os.Remove(filepath.Join(opts.MasterOutPutPath, "master.xlsx")) - }() + // defer func() { + // os.Remove(filepath.Join(opts.MasterOutPutPath, "master.xlsx")) + // }() if err := DatamapToDB(&opts); err != nil { t.Fatalf("Unable to write datamap to database file because %v.", err) @@ -43,4 +52,97 @@ func TestWriteMaster(t *testing.T) { if err := CreateMaster(&opts); err != nil { t.Error(err) } + + var tests = []struct { + key string + filename string + sheet string + cellref string + value string + }{ + {"A Date", "test_template.xlsx", "Summary", "B2", "20/10/19"}, + {"A String", "test_template.xlsx", "Summary", "B3", "This is a string"}, + {"A String2", "test_template.xlsx", "Summary", "C3", "This is a string"}, + {"A String3", "test_template.xlsx", "Summary", "D3", "This is a string"}, + {"A Float", "test_template.xlsx", "Summary", "B4", "2.2"}, + {"An Integer", "test_template.xlsx", "Summary", "B5", "10"}, + {"A Date 1", "test_template.xlsx", "Another Sheet", "B3", "20/10/19"}, + {"A String 1", "test_template.xlsx", "Another Sheet", "B4", "This is a string"}, + {"A Float 1", "test_template.xlsx", "Another Sheet", "B5", "2.2"}, + {"An Integer 1", "test_template.xlsx", "Another Sheet", "B6", "10"}, + {"A Date 2", "test_template.xlsx", "Another Sheet", "D3", "20/10/19"}, + {"A String 2", "test_template.xlsx", "Another Sheet", "D4", "This is a string"}, + {"A Float 3", "test_template.xlsx", "Another Sheet", "D5", "3.2"}, + {"An Integer 3", "test_template.xlsx", "Another Sheet", "D6", "11"}, + {"A Ten Integer", "test_template.xlsx", "Introduction", "A1", "10"}, + {"A Test String", "test_template.xlsx", "Introduction", "C9", "Test Department"}, + {"A Vunt String", "test_template.xlsx", "Introduction", "C22", "VUNT"}, + {"A Parrot String", "test_template.xlsx", "Introduction", "J9", "Greedy Parrots"}, + } + + // Regular testing of import + // TODO fix date formatting + for _, test := range tests { + sql := fmt.Sprintf(`SELECT return_data.value FROM return_data, datamap_line + WHERE + (return_data.filename=%q + AND datamap_line.cellref=%q + AND datamap_line.sheet=%q + AND return_data.dml_id=datamap_line.id);`, test.filename, test.cellref, test.sheet) + + got, err := exec.Command("sqlite3", opts.DBPath, sql).Output() + if err != nil { + t.Fatalf("something wrong %v", err) + } + got_s := strings.TrimSuffix(string(got), "\n") + if strings.Compare(got_s, test.value) != 0 { + t.Errorf("we wanted %s but got %s", test.value, got_s) + } + } + + // TODO: Testing master + + // The algorthim for this is as follows: + // - get all the file names in a set from the header row + // - go through each row and map the key/value coordinates for each file + // - when going through each test struct, look up the map created in step + // above to get the value. + + // Open the master and the target sheet + master, err := xlsx.OpenFile("./testdata/master.xlsx") + if err != nil { + t.Fatal(err) + } + sheetName := "Master Data" + sh, ok := master.Sheet[sheetName] + if !ok { + t.Errorf("Sheet named %s does not exist", sheetName) + } + defer sh.Close() + + err = sh.ForEachRow(rowVisitorTest) + +} + +func cellVisitorTest(c *xlsx.Cell) error { + filesInMaster = append(filesInMaster, c.Value) + fileToColIdx[c.Value] = c.Row.GetCoordinate() // NOT RIGHT - GETTING INDEX FOR ROW + return nil +} + +func rowVisitorTest(r *xlsx.Row) error { + // TODO here we want to first find the file names from the header row, + // then test that all key (from col 0) matches the value. + + if r.GetCoordinate() == 0 { + r.ForEachCell(cellVisitorTest) + return nil + } + // var key string + // key = r.GetCell(0).Value + // for idx, fn := range filesInMaster { + // // TODO + // } + fmt.Println(r) + return nil } |