aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTrial97 <alexandru.tripon97@gmail.com>2023-06-15 14:25:58 +0300
committerTrial97 <alexandru.tripon97@gmail.com>2023-06-15 14:25:58 +0300
commit1b42b9a08e5777fcf0d2578f3ffa05e354e47f9a (patch)
tree5c7a9c15cbc37925460b8acfb41bdcf995a8dfa2
parent535fb2c4d6af12b5dc8d39770aee8769833a6199 (diff)
downloadPrismLauncher-1b42b9a08e5777fcf0d2578f3ffa05e354e47f9a.tar.gz
PrismLauncher-1b42b9a08e5777fcf0d2578f3ffa05e354e47f9a.tar.bz2
PrismLauncher-1b42b9a08e5777fcf0d2578f3ffa05e354e47f9a.zip
Fixed tests
Signed-off-by: Trial97 <alexandru.tripon97@gmail.com>
-rw-r--r--launcher/settings/INIFile.cpp6
-rw-r--r--tests/INIFile_test.cpp39
2 files changed, 23 insertions, 22 deletions
diff --git a/launcher/settings/INIFile.cpp b/launcher/settings/INIFile.cpp
index ad600ab9..d16256b9 100644
--- a/launcher/settings/INIFile.cpp
+++ b/launcher/settings/INIFile.cpp
@@ -98,7 +98,7 @@ QString unescape(QString orig)
return out;
}
-QString unquete(QString str)
+QString unquote(QString str)
{
if ((str.contains(QChar(';')) || str.contains(QChar('=')) || str.contains(QChar(','))) && str.endsWith("\"") && str.startsWith("\"")) {
#if QT_VERSION < QT_VERSION_CHECK(6, 5, 0)
@@ -138,7 +138,7 @@ bool parseOldFileFormat(QIODevice& device, QSettings::SettingsMap& map)
QString key = line.left(eqPos).trimmed();
QString valueStr = line.right(line.length() - eqPos - 1).trimmed();
- valueStr = unquete(unescape(valueStr));
+ valueStr = unquote(unescape(valueStr));
QVariant value(valueStr);
map.insert(key, value);
@@ -174,7 +174,7 @@ bool INIFile::loadFile(QString fileName)
if (auto valueStr = _settings_obj.value(key).toString();
(valueStr.contains(QChar(';')) || valueStr.contains(QChar('=')) || valueStr.contains(QChar(','))) &&
valueStr.endsWith("\"") && valueStr.startsWith("\"")) {
- insert(key, unquete(valueStr));
+ insert(key, unquote(valueStr));
} else
insert(key, _settings_obj.value(key));
}
diff --git a/tests/INIFile_test.cpp b/tests/INIFile_test.cpp
index 5d9c9cd8..eaf077d4 100644
--- a/tests/INIFile_test.cpp
+++ b/tests/INIFile_test.cpp
@@ -3,6 +3,7 @@
#include <settings/INIFile.h>
#include <QList>
#include <QSettings>
+#include <QTemporaryFile>
#include <QVariant>
#include "FileSystem.h"
@@ -74,9 +75,8 @@ class IniFileTest : public QObject {
QCOMPARE(out_list_numbers, list_numbers);
}
- void test_SaveAleardyExistingFile()
+ void test_SaveAlreadyExistingFile()
{
- QString fileName = "test_SaveAleardyExistingFile.ini";
QString fileContent = R"(InstanceType=OneSix
iconKey=vanillia_icon
name=Minecraft Vanillia
@@ -86,9 +86,10 @@ Wrapperommand=)";
fileContent += "\"";
fileContent += +R"(\"$INST_JAVA\" -jar packwiz-installer-bootstrap.jar link =)";
fileContent += "\"\n";
- QFile file(fileName);
+ QTemporaryFile file;
- if (file.open(QFile::WriteOnly | QFile::Text)) {
+ // QFile file(fileName);
+ if (file.open()) {
QTextStream stream(&file);
stream << fileContent;
file.close();
@@ -96,22 +97,23 @@ Wrapperommand=)";
// load
INIFile f1;
- f1.loadFile(fileName);
+ f1.loadFile(file.fileName());
QCOMPARE(f1.get("PreLaunchCommand", "NOT SET").toString(), "\"$INST_JAVA\" -jar packwiz-installer-bootstrap.jar link");
QCOMPARE(f1.get("Wrapperommand", "NOT SET").toString(), "\"$INST_JAVA\" -jar packwiz-installer-bootstrap.jar link =");
- f1.saveFile(fileName);
+ f1.saveFile(file.fileName());
INIFile f2;
- f2.loadFile(fileName);
+ f2.loadFile(file.fileName());
QCOMPARE(f2.get("PreLaunchCommand", "NOT SET").toString(), "\"$INST_JAVA\" -jar packwiz-installer-bootstrap.jar link");
QCOMPARE(f2.get("Wrapperommand", "NOT SET").toString(), "\"$INST_JAVA\" -jar packwiz-installer-bootstrap.jar link =");
QCOMPARE(f2.get("ConfigVersion", "NOT SET").toString(), "1.2");
}
- void test_SaveAleardyExistingFileWithSpecialChars()
+ void test_SaveAlreadyExistingFileWithSpecialChars()
{
- QString fileName = "test_SaveAleardyExistingFileWithSpecialChars.ini";
- FS::deletePath(fileName); // just to clean the previous test run
- QSettings settings{ fileName, QSettings::Format::IniFormat };
+ QTemporaryFile file;
+ file.open();
+ file.close();
+ QSettings settings{ file.fileName(), QSettings::Format::IniFormat };
settings.setFallbacksEnabled(false);
settings.setValue("simple", "value1");
@@ -127,20 +129,20 @@ Wrapperommand=)";
// load
INIFile f1;
- f1.loadFile(fileName);
+ f1.loadFile(file.fileName());
for (auto key : settings.allKeys())
QCOMPARE(f1.get(key, "NOT SET").toString(), settings.value(key).toString());
- f1.saveFile(fileName);
+ f1.saveFile(file.fileName());
INIFile f2;
- f2.loadFile(fileName);
+ f2.loadFile(file.fileName());
for (auto key : settings.allKeys())
QCOMPARE(f2.get(key, "NOT SET").toString(), settings.value(key).toString());
QCOMPARE(f2.get("ConfigVersion", "NOT SET").toString(), "1.2");
}
- void test_SaveAleardyExistingFileWithSpecialCharsV1()
+ void test_SaveAlreadyExistingFileWithSpecialCharsV1()
{
- QString fileName = "test_SaveAleardyExistingFileWithSpecialCharsV1.ini";
+ QTemporaryFile file;
QString fileContent = R"(InstanceType=OneSix
ConfigVersion=1.1
iconKey=vanillia_icon
@@ -148,9 +150,8 @@ name=Minecraft Vanillia
OverrideCommands=true
PreLaunchCommand=)";
fileContent += "\"\\\"env mesa=true\\\"\"\n";
- QFile file(fileName);
- if (file.open(QFile::WriteOnly | QFile::Text)) {
+ if (file.open()) {
QTextStream stream(&file);
stream << fileContent;
file.close();
@@ -158,7 +159,7 @@ PreLaunchCommand=)";
// load
INIFile f1;
- f1.loadFile(fileName);
+ f1.loadFile(file.fileName());
QCOMPARE(f1.get("PreLaunchCommand", "NOT SET").toString(), "env mesa=true");
QCOMPARE(f1.get("ConfigVersion", "NOT SET").toString(), "1.2");
}