From 73e42a5e67c5d166a36bfe1473ef1ec05a761168 Mon Sep 17 00:00:00 2001 From: Matthew Lemon Date: Sun, 26 Jul 2020 17:14:25 +0100 Subject: adding test and code for pulling []DatamapLine from sqlite3 file --- pkg/datamaps/reader.go | 34 ++++++++++++++++++++++++++++++++++ pkg/datamaps/reader_test.go | 44 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 78 insertions(+) diff --git a/pkg/datamaps/reader.go b/pkg/datamaps/reader.go index bc339e8..ef4ef1a 100644 --- a/pkg/datamaps/reader.go +++ b/pkg/datamaps/reader.go @@ -4,6 +4,7 @@ package datamaps import ( + "database/sql" "encoding/csv" "errors" "fmt" @@ -146,6 +147,39 @@ func ReadXLSX(ssheet string) FileData { return outer } +func DMLFromDB(name string, db *sql.DB) []DatamapLine { + + query := ` + select + key, sheet, cellref + from datamap_line + join datamap on datamap_line.dm_id = datamap.id where datamap.name = ?; + ` + rows, err := db.Query(query, name) + if err != nil { + log.Fatal(err) + } + defer rows.Close() + + for rows.Next() { + var ( + key string + sheet string + cellref string + ) + if err := rows.Scan(&key, &sheet, &cellref); err != nil { + log.Fatal(err) + } + log.Printf("key %s\nsheet %s\ncellref %v", key, sheet, cellref) + } + return make([]DatamapLine, 0) +} + +// func ExtractDBDM(name string, file string) ExtractedData { +// xdata := ReadXLSX(file) +// // ddata, err := DMLFromDB(name) // this will need to return a []DatamapLine +// } + //Extract returns the file's data as a map, // using the datamap as a filter, keyed on sheet name. All values // are returned as strings. diff --git a/pkg/datamaps/reader_test.go b/pkg/datamaps/reader_test.go index a0b3ffe..be89e5f 100644 --- a/pkg/datamaps/reader_test.go +++ b/pkg/datamaps/reader_test.go @@ -70,6 +70,50 @@ func TestReadXLSX(t *testing.T) { } } +// func TestExtractWithDBDatamap(t *testing.T) { +// // setup - we need the datamap in the test database +// db, err := SetupDB("./testdata/test.db") +// defer db.Close() + +// if err != nil { +// t.Fatal("Expected to be able to set up the database.") +// } + +// opts := Options{ +// DBPath: "./testdata/test.db", +// DMName: "First Datamap", +// DMPath: "./testdata/datamap.csv", +// } + +// if err := DatamapToDB(&opts); err != nil { +// t.Errorf("Unable to write datamap to database file because %v.", err) +// } + +// d := ExtractDBDM("First Datamap", "testdata/test_template.xlsx") +// } + +func TestDMLSliceFromDatabase(t *testing.T) { + // setup - we need the datamap in the test database + db, err := SetupDB("./testdata/test.db") + defer db.Close() + + if err != nil { + t.Fatal("Expected to be able to set up the database.") + } + + opts := Options{ + DBPath: "./testdata/test.db", + DMName: "First Datamap", + DMPath: "./testdata/datamap.csv", + } + + if err := DatamapToDB(&opts); err != nil { + t.Errorf("Unable to write datamap to database file because %v.", err) + } + data := DMLFromDB("First Datamap", db) + t.Log(data) +} + func TestExtract(t *testing.T) { d := Extract("testdata/datamap.csv", "testdata/test_template.xlsx") cases := []struct { -- cgit v1.2.3