summaryrefslogtreecommitdiff
path: root/java/test/IceUtil/fileLock/ClientFail.java
diff options
context:
space:
mode:
Diffstat (limited to 'java/test/IceUtil/fileLock/ClientFail.java')
-rw-r--r--java/test/IceUtil/fileLock/ClientFail.java81
1 files changed, 81 insertions, 0 deletions
diff --git a/java/test/IceUtil/fileLock/ClientFail.java b/java/test/IceUtil/fileLock/ClientFail.java
new file mode 100644
index 00000000000..bda4bce6fbc
--- /dev/null
+++ b/java/test/IceUtil/fileLock/ClientFail.java
@@ -0,0 +1,81 @@
+// **********************************************************************
+//
+// 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.
+//
+// **********************************************************************
+
+package test.IceUtil.fileLock;
+
+import java.io.BufferedReader;
+import java.io.InputStreamReader;
+
+import java.io.File;
+import java.io.RandomAccessFile;
+import java.io.EOFException;
+import java.io.UTFDataFormatException;
+import java.io.IOException;
+
+
+public class ClientFail
+{
+ private static void
+ test(boolean b)
+ {
+ if(!b)
+ {
+ throw new RuntimeException();
+ }
+ }
+
+ public static void
+ main(String[] argvs)
+ {
+ IceUtilInternal.FileLock lock = null;
+ try
+ {
+ lock = new IceUtilInternal.FileLock("file.lock");
+ test(false);
+ }
+ catch(IceUtil.FileLockException ex)
+ {
+ System.out.println("File lock not acquired.");
+ //
+ // Try to read the pid of the lock owner from the lock file, in Windows
+ // we don't write pid to lock files.
+ //
+ if(!System.getProperty("os.name").startsWith("Windows"))
+ {
+ String pid = "";
+ try
+ {
+ RandomAccessFile file = new RandomAccessFile(new File("file.lock"), "r");
+ pid = file.readUTF();
+ }
+ catch(EOFException eofEx)
+ {
+ System.out.println("exception:\n" + eofEx.toString());
+ test(false);
+ }
+ catch(UTFDataFormatException utfEx)
+ {
+ System.out.println("exception:\n" + utfEx.toString());
+ test(false);
+ }
+ catch(IOException ioEx)
+ {
+ System.out.println("exception:\n" + ioEx.toString());
+ test(false);
+ }
+
+ if(pid.isEmpty())
+ {
+ test(false);
+ }
+ System.out.println("Lock owned by: " + pid);
+ }
+ }
+ }
+}