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
|
/*
* 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 ChmodTest: public testing::Test {
public:
static const char* root;
static int n_modes;
static mode_t *modes;
char surl[2048];
gfal2_context_t context;
ChmodTest() {
GError *error = NULL;
context = gfal2_context_new(&error);
Gfal::gerror_to_cpp(&error);
}
virtual ~ChmodTest() {
gfal2_context_free(context);
}
virtual void SetUp() {
GError* error = NULL;
generate_random_uri(root, "chmod_test", surl, sizeof(surl));
int ret = gfal2_mkdir(context, surl, 0775, &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
}
virtual void TearDown() {
GError* error = NULL;
gfal2_chmod(context, surl, 0777, &error);
g_clear_error(&error);
gfal2_rmdir(context, surl, &error);
g_clear_error(&error);
}
};
const char* ChmodTest::root;
int ChmodTest::n_modes = 0;
mode_t* ChmodTest::modes = NULL;
TEST_F(ChmodTest, SimpleChmod)
{
GError* error = NULL;
struct stat st;
int ret = gfal2_stat(context, surl, &st, &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
mode_t original_mode = st.st_mode;
int i;
for (i = 0; i < n_modes; ++i) {
ret = gfal2_chmod(context, surl, modes[i], &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
ret = gfal2_stat(context, surl, &st, &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
EXPECT_EQ(modes[i], st.st_mode & 0777);
};
ret = gfal2_chmod(context, surl, original_mode, &error);
EXPECT_PRED_FORMAT2(AssertGfalSuccess, ret, error);
}
int main(int argc, char** argv)
{
testing::InitGoogleTest(&argc, argv);
if (argc < 3) {
printf("Missing base url and/or modes\n");
printf("\t%s [options] srm://host/base/path/ 0777 0555 0000....\n", argv[0]);
return 1;
}
ChmodTest::root = argv[1];
ChmodTest::n_modes = argc - 2;
ChmodTest::modes = new mode_t[ChmodTest::n_modes];
int i;
for (i = 2; i < argc; ++i) {
errno = 0;
ChmodTest::modes[i - 2] = (mode_t)strtol(argv[i], NULL, 8);
if (errno) {
perror ("strtol");
exit (1);
}
}
int result = RUN_ALL_TESTS();
delete[] ChmodTest::modes;
return result;
}
|