From 1580fe7c9696654803a93da8cf372f75e75149fa Mon Sep 17 00:00:00 2001 From: 0penBrain <48731257+0penBrain@users.noreply.github.com> Date: Fri, 26 May 2023 11:06:10 +0200 Subject: [PATCH] Spreadsheet: update and add tests --- src/Mod/Spreadsheet/TestSpreadsheet.py | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/src/Mod/Spreadsheet/TestSpreadsheet.py b/src/Mod/Spreadsheet/TestSpreadsheet.py index bd82a36c61..80b2ad3e04 100644 --- a/src/Mod/Spreadsheet/TestSpreadsheet.py +++ b/src/Mod/Spreadsheet/TestSpreadsheet.py @@ -1082,7 +1082,7 @@ class SpreadsheetCases(unittest.TestCase): self.doc.recompute() sheet.set('A3', '') sheet.set('A3', 'A1') - self.assertEqual(sheet.getContents('A3'), 'A1') + self.assertEqual(sheet.getContents('A3'), '\'A1') def testInsertRowsAlias(self): """ Regression test for issue 4429; insert rows to sheet with aliases""" @@ -1448,6 +1448,21 @@ class SpreadsheetCases(unittest.TestCase): self.assertEqual(sheet.getContents('A1'), '=1 == 1 ? 1 : 0') self.assertEqual(sheet.A1, 1) + def testIssue6395(self): + """ Testing strings are correctly saved and restored""" + sheet = self.doc.addObject('Spreadsheet::Sheet','Spreadsheet') + sheet.set('A1', '\'36C') # Use a string that may be parsed as a quantity + self.doc.recompute() + + self.doc.saveAs(self.TempPath + os.sep + 'string.fcstd') + FreeCAD.closeDocument(self.doc.Name) + + self.doc = FreeCAD.openDocument(self.TempPath + os.sep + 'string.fcstd') + + sheet = self.doc.getObject('Spreadsheet') + self.assertEqual(sheet.getContents('A1'), '\'36C') + self.assertEqual(sheet.get('A1'), '36C') + def tearDown(self): #closing doc FreeCAD.closeDocument(self.doc.Name)