Mercurial > hg > CbC > CbC_llvm
view unittests/Support/LockFileManagerTest.cpp @ 56:bdef5c940791
copy the previous function's return type to return value
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Thu, 23 Jan 2014 23:14:57 +0900 |
parents | 95c75e76d11b |
children | 54457678186b |
line wrap: on
line source
//===- unittests/LockFileManagerTest.cpp - LockFileManager tests ----------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "llvm/Support/LockFileManager.h" #include "llvm/Support/FileSystem.h" #include "llvm/Support/Path.h" #include "gtest/gtest.h" #include <memory> using namespace llvm; namespace { TEST(LockFileManagerTest, Basic) { SmallString<64> TmpDir; error_code EC; EC = sys::fs::createUniqueDirectory("LockFileManagerTestDir", TmpDir); ASSERT_FALSE(EC); SmallString<64> LockedFile(TmpDir); sys::path::append(LockedFile, "file.lock"); { // The lock file should not exist, so we should successfully acquire it. LockFileManager Locked1(LockedFile); EXPECT_EQ(LockFileManager::LFS_Owned, Locked1.getState()); // Attempting to reacquire the lock should fail. Waiting on it would cause // deadlock, so don't try that. LockFileManager Locked2(LockedFile); EXPECT_NE(LockFileManager::LFS_Owned, Locked2.getState()); } // Now that the lock is out of scope, the file should be gone. EXPECT_FALSE(sys::fs::exists(StringRef(LockedFile))); sys::fs::remove_all(StringRef(TmpDir)); } } // end anonymous namespace