aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--pkg/datamaps/db.go11
-rw-r--r--pkg/datamaps/writer.go10
-rw-r--r--pkg/datamaps/writer_test.go6
3 files changed, 16 insertions, 11 deletions
diff --git a/pkg/datamaps/db.go b/pkg/datamaps/db.go
index 80724ce..d95bfd7 100644
--- a/pkg/datamaps/db.go
+++ b/pkg/datamaps/db.go
@@ -49,6 +49,7 @@ func setupDB(path string) (*sql.DB, error) {
filename TEXT,
value TEXT,
numfmt TEXT,
+ vFormatted TEXT,
FOREIGN KEY (dml_id)
REFERENCES datamap_line(id)
ON DELETE CASCADE
@@ -236,14 +237,18 @@ func importXLSXtoDB(dmName string, returnName string, file string, db *sql.DB) e
log.Println(err.Error())
}
- // TODO - here we need to store the c.NumFmt string value in a new field
- insertStmt, err := db.Prepare("insert into return_data (dml_id, ret_id, filename, value, numfmt) values(?,?,?,?,?)")
+ insertStmt, err := db.Prepare("insert into return_data (dml_id, ret_id, filename, value, numfmt, vFormatted) values(?,?,?,?,?,?)")
if err != nil {
log.Fatal(err)
}
defer insertStmt.Close()
- _, err = insertStmt.Exec(dmlID, retID, filename, cellData.Value, cellData.NumFmt)
+ fValue, err := cellData.FormattedValue()
+ if err != nil {
+ return err
+ }
+
+ _, err = insertStmt.Exec(dmlID, retID, filename, cellData.Value, cellData.NumFmt, fValue)
if err != nil {
log.Fatal(err)
}
diff --git a/pkg/datamaps/writer.go b/pkg/datamaps/writer.go
index a3c3698..9595132 100644
--- a/pkg/datamaps/writer.go
+++ b/pkg/datamaps/writer.go
@@ -71,7 +71,7 @@ func CreateMaster(opts *Options) error {
return err
}
- getDataSQL := `SELECT datamap_line.key, return_data.value, return_data.filename
+ getDataSQL := `SELECT datamap_line.key, return_data.vFormatted, return_data.filename
FROM (((return_data
INNER JOIN datamap_line ON return_data.dml_id=datamap_line.id)
INNER JOIN datamap ON datamap_line.dm_id=datamap.id)
@@ -89,11 +89,11 @@ func CreateMaster(opts *Options) error {
return err
}
for masterData.Next() {
- var key, filename, value, numFmt string
- if err := masterData.Scan(&key, &value, &filename, &numFmt); err != nil {
- return err
+ var key, filename, fmttedValue string
+ if err := masterData.Scan(&key, &fmttedValue, &filename); err != nil {
+ fmt.Errorf("Problem scanning data from database for master: %v", err)
}
- values, err = appendValueMap(key, value, values)
+ values, err = appendValueMap(key, fmttedValue, values)
if _, ok := seen[filename]; !ok {
headerSlice = append(headerSlice, filename)
seen[filename] = struct{}{}
diff --git a/pkg/datamaps/writer_test.go b/pkg/datamaps/writer_test.go
index 412d7ba..e16ce10 100644
--- a/pkg/datamaps/writer_test.go
+++ b/pkg/datamaps/writer_test.go
@@ -71,7 +71,7 @@ func TestWriteMaster(t *testing.T) {
{"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 Date 2", "test_template.xlsx", "Another Sheet", "D3", "21/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"},
@@ -90,7 +90,7 @@ func TestWriteMaster(t *testing.T) {
{"A String 1", "test_template.xlsm", "Another Sheet", "B4", "This is a string"},
{"A Float 1", "test_template.xlsm", "Another Sheet", "B5", "2.2"},
{"An Integer 1", "test_template.xlsm", "Another Sheet", "B6", "10"},
- {"A Date 2", "test_template.xlsm", "Another Sheet", "D3", "20/10/19"},
+ {"A Date 2", "test_template.xlsm", "Another Sheet", "D3", "21/10/19"},
{"A String 2", "test_template.xlsm", "Another Sheet", "D4", "This is a string"},
{"A Float 3", "test_template.xlsm", "Another Sheet", "D5", "3.2"},
{"An Integer 3", "test_template.xlsm", "Another Sheet", "D6", "11"},
@@ -103,7 +103,7 @@ func TestWriteMaster(t *testing.T) {
// Regular testing of import
// TODO fix date formatting
for _, test := range tests {
- sql := fmt.Sprintf(`SELECT return_data.value FROM return_data, datamap_line
+ sql := fmt.Sprintf(`SELECT return_data.vFormatted FROM return_data, datamap_line
WHERE
(return_data.filename=%q
AND datamap_line.cellref=%q