diff PostgreSQL/UnitTests/UnitTestsMain.cpp @ 0:7cea966b6829

initial commit
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 04 Jul 2018 08:16:29 +0200
parents
children 9774802fd05f
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/PostgreSQL/UnitTests/UnitTestsMain.cpp	Wed Jul 04 08:16:29 2018 +0200
@@ -0,0 +1,171 @@
+/**
+ * Orthanc - A Lightweight, RESTful DICOM Store
+ * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
+ * Department, University Hospital of Liege, Belgium
+ * Copyright (C) 2017-2018 Osimis S.A., Belgium
+ *
+ * This program is free software: you can redistribute it and/or
+ * modify it under the terms of the GNU Affero General Public License
+ * as published by the Free Software Foundation, either version 3 of
+ * the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Affero General Public License for more details.
+ * 
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ **/
+
+
+#include "../Plugins/PostgreSQLIndex.h"
+
+#include <Core/Logging.h>
+#include <gtest/gtest.h>
+
+OrthancDatabases::PostgreSQLParameters  globalParameters_;
+
+#include "../../Framework/Plugins/IndexUnitTests.h"
+
+
+TEST(PostgreSQLParameters, Basic)
+{
+  OrthancDatabases::PostgreSQLParameters p;
+  p.SetDatabase("world");
+
+  ASSERT_EQ("postgresql://localhost:5432/world", p.GetConnectionUri());
+
+  p.ResetDatabase();
+  ASSERT_EQ("postgresql://localhost:5432/", p.GetConnectionUri());
+
+  p.SetDatabase("hello");
+  ASSERT_EQ("postgresql://localhost:5432/hello", p.GetConnectionUri());
+
+  p.SetHost("server");
+  ASSERT_EQ("postgresql://server:5432/hello", p.GetConnectionUri());
+
+  p.SetPortNumber(1234);
+  ASSERT_EQ("postgresql://server:1234/hello", p.GetConnectionUri());
+
+  p.SetPortNumber(5432);
+  ASSERT_EQ("postgresql://server:5432/hello", p.GetConnectionUri());
+
+  p.SetUsername("user");
+  p.SetPassword("pass");
+  ASSERT_EQ("postgresql://user:pass@server:5432/hello", p.GetConnectionUri());
+
+  p.SetPassword("");
+  ASSERT_EQ("postgresql://user@server:5432/hello", p.GetConnectionUri());
+
+  p.SetUsername("");
+  p.SetPassword("pass");
+  ASSERT_EQ("postgresql://server:5432/hello", p.GetConnectionUri());
+
+  p.SetUsername("");
+  p.SetPassword("");
+  ASSERT_EQ("postgresql://server:5432/hello", p.GetConnectionUri());
+
+  p.SetConnectionUri("hello://world");
+  ASSERT_EQ("hello://world", p.GetConnectionUri());
+}
+
+
+TEST(PostgreSQLIndex, Lock)
+{
+  OrthancDatabases::PostgreSQLParameters noLock = globalParameters_;
+  noLock.SetLock(false);
+
+  OrthancDatabases::PostgreSQLParameters lock = globalParameters_;
+  lock.SetLock(true);
+
+  OrthancDatabases::PostgreSQLIndex db1(noLock);
+  db1.SetClearAll(true);
+  db1.Open();
+
+  {
+    OrthancDatabases::PostgreSQLIndex db2(lock);
+    db2.Open();
+
+    OrthancDatabases::PostgreSQLIndex db3(lock);
+    ASSERT_THROW(db3.Open(), Orthanc::OrthancException);
+  }
+
+  OrthancDatabases::PostgreSQLIndex db4(lock);
+  db4.Open();
+}
+
+
+#if 0
+TEST(PostgreSQL, StorageArea)
+{
+  std::auto_ptr<PostgreSQLDatabase> pg(CreateTestDatabase(true));
+  PostgreSQLStorageArea s(pg.release(), true, true);
+
+  ASSERT_EQ(0, CountLargeObjects(s.GetDatabase()));
+  
+  for (int i = 0; i < 10; i++)
+  {
+    std::string uuid = boost::lexical_cast<std::string>(i);
+    std::string value = "Value " + boost::lexical_cast<std::string>(i * 2);
+    s.Create(uuid, value.c_str(), value.size(), OrthancPluginContentType_Unknown);
+  }
+
+  std::string tmp;
+  ASSERT_THROW(s.Read(tmp, "nope", OrthancPluginContentType_Unknown), Orthanc::OrthancException);
+  
+  ASSERT_EQ(10, CountLargeObjects(s.GetDatabase()));
+  s.Remove("5", OrthancPluginContentType_Unknown);
+  ASSERT_EQ(9, CountLargeObjects(s.GetDatabase()));
+
+  for (int i = 0; i < 10; i++)
+  {
+    std::string uuid = boost::lexical_cast<std::string>(i);
+    std::string expected = "Value " + boost::lexical_cast<std::string>(i * 2);
+    std::string content;
+
+    if (i == 5)
+    {
+      ASSERT_THROW(s.Read(content, uuid, OrthancPluginContentType_Unknown), Orthanc::OrthancException);
+    }
+    else
+    {
+      s.Read(content, uuid, OrthancPluginContentType_Unknown);
+      ASSERT_EQ(expected, content);
+    }
+  }
+
+  s.Clear();
+  ASSERT_EQ(0, CountLargeObjects(s.GetDatabase()));
+}
+#endif
+
+
+int main(int argc, char **argv)
+{
+  if (argc < 6)
+  {
+    std::cerr << "Usage: " << argv[0] << " <host> <port> <username> <password> <database>"
+              << std::endl << std::endl
+              << "Example: " << argv[0] << " localhost 5432 postgres postgres orthanctest"
+              << std::endl << std::endl;
+    return -1;
+  }
+
+  globalParameters_.SetHost(argv[1]);
+  globalParameters_.SetPortNumber(boost::lexical_cast<uint16_t>(argv[2]));
+  globalParameters_.SetUsername(argv[3]);
+  globalParameters_.SetPassword(argv[4]);
+  globalParameters_.SetDatabase(argv[5]);
+
+  ::testing::InitGoogleTest(&argc, argv);
+  Orthanc::Logging::Initialize();
+  Orthanc::Logging::EnableInfoLevel(true);
+  Orthanc::Logging::EnableTraceLevel(true);
+
+  int result = RUN_ALL_TESTS();
+
+  Orthanc::Logging::Finalize();
+
+  return result;
+}