1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126
|
/*
* Copyright (c) CERN 2013-2017
*
* Copyright (c) Members of the EMI Collaboration. 2010-2013
* See http://www.eu-emi.eu/partners for details on the copyright
* holders.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <gtest/gtest.h>
#include <fcntl.h>
#include <stdio.h>
#include <gfal_api.h>
#include <stdlib.h>
#include <common/gfal_lib_test.h>
#include <common/gfal_gtest_asserts.h>
#include <utils/exceptions/gerror_to_cpp.h>
class RenameTest: public testing::Test {
public:
static const char* root;
char origin[2048];
char destination[2048];
gfal2_context_t context;
RenameTest() {
GError *error = NULL;
context = gfal2_context_new(&error);
Gfal::gerror_to_cpp(&error);
}
virtual ~RenameTest() {
gfal2_context_free(context);
}
virtual void SetUp() {
generate_random_uri(root, "rename_test", origin, sizeof(origin));
generate_random_uri(root, "rename_test", destination, sizeof(destination));
}
virtual void ForceRm(const char *surl) {
GError* error = NULL;
if (gfal2_rmdir(context, surl, &error) != 0) {
g_clear_error(&error);
gfal2_unlink(context, surl, &error);
}
g_clear_error(&error);
}
virtual void TearDown() {
ForceRm(origin);
ForceRm(destination);
}
};
const char* RenameTest::root;
// Rename a file to a different name, destination does not exist
TEST_F(RenameTest, SimpleRename)
{
GError* error = NULL;
int ret = generate_file_if_not_exists(context, origin, "file:///etc/hosts", &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
ret = gfal2_rename(context, origin, destination, &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
struct stat buf;
ret = gfal2_stat(context, origin, &buf, &error);
EXPECT_PRED_FORMAT3(AssertGfalErrno, ret, error, ENOENT);
g_clear_error(&error);
ret = gfal2_stat(context, destination, &buf, &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
}
// Rename a file, but the new name already exists and is a directory
TEST_F(RenameTest, RenameToExisting)
{
if (strncmp(origin, "srm://", 6) == 0 || strncmp(origin, "davs", 4) == 0) {
SKIP_TEST(RenameToExisting);
return;
}
GError* error = NULL;
int ret = generate_file_if_not_exists(context, origin, "file:///etc/hosts", &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
ret = gfal2_mkdir(context, destination, 0775, &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
ret = gfal2_rename(context, origin, destination, &error);
EXPECT_PRED_FORMAT3(AssertGfalErrno, ret, error, EISDIR);
}
int main(int argc, char** argv)
{
testing::InitGoogleTest(&argc, argv);
if (argc < 2) {
printf("Missing base url\n");
printf("\t%s [options] srm://host/base/path/\n", argv[0]);
return 1;
}
RenameTest::root = argv[1];
return RUN_ALL_TESTS();
}
|