summaryrefslogtreecommitdiff
path: root/cpp/test/Freeze/fileLock/ClientFail.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/test/Freeze/fileLock/ClientFail.cpp')
-rw-r--r--cpp/test/Freeze/fileLock/ClientFail.cpp80
1 files changed, 80 insertions, 0 deletions
diff --git a/cpp/test/Freeze/fileLock/ClientFail.cpp b/cpp/test/Freeze/fileLock/ClientFail.cpp
new file mode 100644
index 00000000000..caeefff91f6
--- /dev/null
+++ b/cpp/test/Freeze/fileLock/ClientFail.cpp
@@ -0,0 +1,80 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2009 ZeroC, Inc. All rights reserved.
+//
+// This copy of Ice is licensed to you under the terms described in the
+// ICE_LICENSE file included in this distribution.
+//
+// **********************************************************************
+
+#include <IceUtil/IceUtil.h>
+#include <Freeze/Freeze.h>
+#include <TestCommon.h>
+
+using namespace std;
+using namespace Ice;
+using namespace Freeze;
+
+//COMPILERFIX: Borland C++ 2010 doesn't support wmain for console applications.
+#if defined(_WIN32) && !defined(__BCPLUSPLUS__)
+int
+wmain(int argc, wchar_t* argv[])
+
+#else
+
+int
+main(int argc, char* argv[])
+
+#endif
+{
+ int status = EXIT_SUCCESS;
+ Ice::CommunicatorPtr communicator;
+
+ string envName = "db";
+
+ communicator = Ice::initialize(argc, argv);
+ if(argc != 1)
+ {
+#if defined(_WIN32) && !defined(__BCPLUSPLUS__)
+ envName = IceUtil::wstringToString(argv[1]);
+#else
+ envName = argv[1];
+#endif
+ envName += "/db";
+ }
+
+ {
+ Freeze::ConnectionPtr connection;
+ try
+ {
+ connection = Freeze::createConnection(communicator, envName);
+ test(false);
+ }
+ catch(const IceUtil::FileLockException&)
+ {
+ cout << "File lock not acquired." << endl;
+ test(true);
+ }
+ catch(const exception& ex)
+ {
+ cerr << "excetpion:\n" << ex.what() << endl;
+ test(false);
+ }
+ catch(...)
+ {
+ test(false);
+ }
+ }
+
+ try
+ {
+ communicator->destroy();
+ }
+ catch(const Ice::Exception& ex)
+ {
+ cerr << ex << endl;
+ status = EXIT_FAILURE;
+ }
+
+ return status;
+}