Home | History | Annotate | Line # | Download | only in c063
t_o_search.c revision 1.4.12.1
      1  1.4.12.1  pgoyette /*	$NetBSD: t_o_search.c,v 1.4.12.1 2017/03/20 06:57:58 pgoyette Exp $ */
      2       1.1      manu 
      3       1.1      manu /*-
      4       1.1      manu  * Copyright (c) 2012 The NetBSD Foundation, Inc.
      5       1.1      manu  * All rights reserved.
      6       1.1      manu  *
      7       1.1      manu  * This code is derived from software contributed to The NetBSD Foundation
      8       1.1      manu  * by Emmanuel Dreyfus.
      9       1.1      manu  *
     10       1.1      manu  * Redistribution and use in source and binary forms, with or without
     11       1.1      manu  * modification, are permitted provided that the following conditions
     12       1.1      manu  * are met:
     13       1.1      manu  * 1. Redistributions of source code must retain the above copyright
     14       1.1      manu  *    notice, this list of conditions and the following disclaimer.
     15       1.1      manu  * 2. Redistributions in binary form must reproduce the above copyright
     16       1.1      manu  *    notice, this list of conditions and the following disclaimer in the
     17       1.1      manu  *    documentation and/or other materials provided with the distribution.
     18       1.1      manu  *
     19       1.1      manu  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     20       1.1      manu  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     21       1.1      manu  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     22       1.1      manu  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     23       1.1      manu  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     24       1.1      manu  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     25       1.1      manu  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     26       1.1      manu  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     27       1.1      manu  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     28       1.1      manu  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     29       1.1      manu  * POSSIBILITY OF SUCH DAMAGE.
     30       1.1      manu  */
     31       1.1      manu #include <sys/cdefs.h>
     32  1.4.12.1  pgoyette __RCSID("$NetBSD: t_o_search.c,v 1.4.12.1 2017/03/20 06:57:58 pgoyette Exp $");
     33       1.1      manu 
     34       1.1      manu #include <atf-c.h>
     35  1.4.12.1  pgoyette 
     36  1.4.12.1  pgoyette #include <sys/param.h>
     37  1.4.12.1  pgoyette #include <sys/stat.h>
     38  1.4.12.1  pgoyette 
     39       1.1      manu #include <errno.h>
     40       1.1      manu #include <fcntl.h>
     41       1.1      manu #include <limits.h>
     42       1.1      manu #include <paths.h>
     43       1.1      manu #include <stdio.h>
     44       1.1      manu #include <string.h>
     45       1.1      manu #include <unistd.h>
     46       1.1      manu #include <pwd.h>
     47       1.1      manu 
     48       1.3  dholland /*
     49       1.3  dholland  * dholland 20130112: disable tests that require O_SEARCH semantics
     50       1.3  dholland  * until a decision is reached about the semantics of O_SEARCH and a
     51       1.3  dholland  * non-broken implementation is available.
     52       1.3  dholland  */
     53       1.3  dholland #if (O_MASK & O_SEARCH) != 0
     54       1.3  dholland #define USE_O_SEARCH
     55       1.3  dholland #endif
     56       1.3  dholland 
     57       1.1      manu #define DIR "dir"
     58       1.1      manu #define FILE "dir/o_search"
     59       1.1      manu #define BASEFILE "o_search"
     60       1.1      manu 
     61       1.3  dholland 
     62       1.4      jmmv ATF_TC(o_search_perm1);
     63       1.1      manu ATF_TC_HEAD(o_search_perm1, tc)
     64       1.1      manu {
     65       1.3  dholland 	atf_tc_set_md_var(tc, "descr", "See that openat enforces search permission");
     66       1.1      manu 	atf_tc_set_md_var(tc, "require.user", "unprivileged");
     67       1.1      manu }
     68       1.1      manu ATF_TC_BODY(o_search_perm1, tc)
     69       1.1      manu {
     70       1.1      manu 	int dfd;
     71       1.1      manu 	int fd;
     72       1.1      manu 
     73       1.1      manu 	ATF_REQUIRE(mkdir(DIR, 0755) == 0);
     74       1.1      manu 	ATF_REQUIRE((fd = open(FILE, O_CREAT|O_RDWR, 0644)) != -1);
     75       1.1      manu 	ATF_REQUIRE(close(fd) == 0);
     76       1.1      manu 
     77       1.1      manu 	ATF_REQUIRE((dfd = open(DIR, O_RDONLY, 0)) != -1);
     78       1.1      manu 
     79       1.1      manu 	ATF_REQUIRE((fd = openat(dfd, BASEFILE, O_RDWR, 0)) != -1);
     80       1.1      manu 	ATF_REQUIRE(close(fd) == 0);
     81       1.1      manu 
     82       1.1      manu 	ATF_REQUIRE(fchmod(dfd, 644) == 0);
     83       1.1      manu 
     84       1.1      manu 	ATF_REQUIRE((fd = openat(dfd, BASEFILE, O_RDWR, 0)) == -1);
     85       1.1      manu 	ATF_REQUIRE(errno == EACCES);
     86       1.1      manu 
     87       1.1      manu 	ATF_REQUIRE(close(dfd) == 0);
     88       1.1      manu }
     89       1.1      manu 
     90       1.3  dholland #ifdef USE_O_SEARCH
     91       1.3  dholland 
     92       1.4      jmmv ATF_TC(o_search_root_flag1);
     93       1.2    martin ATF_TC_HEAD(o_search_root_flag1, tc)
     94       1.1      manu {
     95       1.3  dholland 	atf_tc_set_md_var(tc, "descr", "See that root openat honours O_SEARCH");
     96       1.2    martin 	atf_tc_set_md_var(tc, "require.user", "root");
     97       1.1      manu }
     98       1.2    martin ATF_TC_BODY(o_search_root_flag1, tc)
     99       1.1      manu {
    100       1.1      manu 	int dfd;
    101       1.1      manu 	int fd;
    102       1.1      manu 
    103       1.1      manu 	ATF_REQUIRE(mkdir(DIR, 0755) == 0);
    104       1.1      manu 	ATF_REQUIRE((fd = open(FILE, O_CREAT|O_RDWR, 0644)) != -1);
    105       1.1      manu 	ATF_REQUIRE(close(fd) == 0);
    106       1.1      manu 
    107       1.1      manu 	ATF_REQUIRE((dfd = open(DIR, O_RDONLY|O_SEARCH, 0)) != -1);
    108       1.1      manu 
    109       1.1      manu 	ATF_REQUIRE((fd = openat(dfd, BASEFILE, O_RDWR, 0)) != -1);
    110       1.1      manu 	ATF_REQUIRE(close(fd) == 0);
    111       1.1      manu 
    112       1.1      manu 	ATF_REQUIRE(fchmod(dfd, 644) == 0);
    113       1.1      manu 
    114       1.1      manu 	ATF_REQUIRE((fd = openat(dfd, BASEFILE, O_RDWR, 0)) != -1);
    115       1.1      manu 	ATF_REQUIRE(close(fd) == 0);
    116       1.1      manu 
    117       1.1      manu 	ATF_REQUIRE(fchmod(dfd, 444) == 0);
    118       1.1      manu 
    119       1.1      manu 	ATF_REQUIRE((fd = openat(dfd, BASEFILE, O_RDWR, 0)) != -1);
    120       1.1      manu 
    121       1.1      manu 	ATF_REQUIRE(close(dfd) == 0);
    122       1.1      manu }
    123       1.1      manu 
    124       1.4      jmmv ATF_TC(o_search_unpriv_flag1);
    125       1.2    martin ATF_TC_HEAD(o_search_unpriv_flag1, tc)
    126       1.2    martin {
    127       1.2    martin 	atf_tc_set_md_var(tc, "descr", "See that openat honours O_SEARCH");
    128       1.2    martin 	atf_tc_set_md_var(tc, "require.user", "unprivileged");
    129       1.2    martin }
    130       1.2    martin ATF_TC_BODY(o_search_unpriv_flag1, tc)
    131       1.2    martin {
    132       1.2    martin 	int dfd;
    133       1.2    martin 	int fd;
    134       1.2    martin 
    135       1.2    martin 	ATF_REQUIRE(mkdir(DIR, 0755) == 0);
    136       1.2    martin 	ATF_REQUIRE((fd = open(FILE, O_CREAT|O_RDWR, 0644)) != -1);
    137       1.2    martin 	ATF_REQUIRE(close(fd) == 0);
    138       1.2    martin 
    139       1.2    martin 	ATF_REQUIRE((dfd = open(DIR, O_RDONLY|O_SEARCH, 0)) != -1);
    140       1.2    martin 
    141       1.2    martin 	ATF_REQUIRE((fd = openat(dfd, BASEFILE, O_RDWR, 0)) != -1);
    142       1.2    martin 	ATF_REQUIRE(close(fd) == 0);
    143       1.2    martin 
    144       1.3  dholland 	ATF_REQUIRE(fchmod(dfd, 644) == 0);
    145       1.2    martin 
    146       1.2    martin 	ATF_REQUIRE((fd = openat(dfd, BASEFILE, O_RDWR, 0)) != -1);
    147       1.2    martin 	ATF_REQUIRE(close(fd) == 0);
    148       1.2    martin 
    149       1.2    martin 	ATF_REQUIRE(fchmod(dfd, 444) == 0);
    150       1.2    martin 
    151       1.3  dholland 	ATF_REQUIRE((fd = openat(dfd, BASEFILE, O_RDWR, 0)) != -1);
    152       1.2    martin 
    153       1.2    martin 	ATF_REQUIRE(close(dfd) == 0);
    154       1.2    martin }
    155       1.2    martin 
    156       1.3  dholland #endif /* USE_O_SEARCH */
    157       1.3  dholland 
    158       1.4      jmmv ATF_TC(o_search_perm2);
    159       1.1      manu ATF_TC_HEAD(o_search_perm2, tc)
    160       1.1      manu {
    161       1.3  dholland 	atf_tc_set_md_var(tc, "descr", "See that faccessat enforces search permission");
    162       1.1      manu 	atf_tc_set_md_var(tc, "require.user", "unprivileged");
    163       1.1      manu }
    164       1.1      manu ATF_TC_BODY(o_search_perm2, tc)
    165       1.1      manu {
    166       1.1      manu 	int dfd;
    167       1.1      manu 	int fd;
    168       1.1      manu 	ATF_REQUIRE(mkdir(DIR, 0755) == 0);
    169       1.1      manu 	ATF_REQUIRE((fd = open(FILE, O_CREAT|O_RDWR, 0644)) != -1);
    170       1.1      manu 	ATF_REQUIRE(close(fd) == 0);
    171       1.1      manu 
    172       1.1      manu 	ATF_REQUIRE((dfd = open(DIR, O_RDONLY, 0)) != -1);
    173       1.1      manu 
    174       1.1      manu 	ATF_REQUIRE(faccessat(dfd, BASEFILE, W_OK, 0) == 0);
    175       1.1      manu 
    176       1.1      manu 	ATF_REQUIRE(fchmod(dfd, 644) == 0);
    177       1.1      manu 
    178       1.1      manu 	ATF_REQUIRE(faccessat(dfd, BASEFILE, W_OK, 0) == -1);
    179       1.1      manu 	ATF_REQUIRE(errno == EACCES);
    180       1.1      manu 
    181       1.1      manu 	ATF_REQUIRE(close(dfd) == 0);
    182       1.1      manu }
    183       1.1      manu 
    184       1.3  dholland #ifdef USE_O_SEARCH
    185       1.3  dholland 
    186       1.4      jmmv ATF_TC(o_search_root_flag2);
    187       1.2    martin ATF_TC_HEAD(o_search_root_flag2, tc)
    188       1.1      manu {
    189       1.3  dholland 	atf_tc_set_md_var(tc, "descr", "See that root fstatat honours O_SEARCH");
    190       1.2    martin 	atf_tc_set_md_var(tc, "require.user", "root");
    191       1.1      manu }
    192       1.2    martin ATF_TC_BODY(o_search_root_flag2, tc)
    193       1.1      manu {
    194       1.1      manu 	int dfd;
    195       1.1      manu 	int fd;
    196       1.1      manu 
    197       1.1      manu 	ATF_REQUIRE(mkdir(DIR, 0755) == 0);
    198       1.1      manu 	ATF_REQUIRE((fd = open(FILE, O_CREAT|O_RDWR, 0644)) != -1);
    199       1.1      manu 	ATF_REQUIRE(close(fd) == 0);
    200       1.1      manu 
    201       1.1      manu 	ATF_REQUIRE((dfd = open(DIR, O_RDONLY|O_SEARCH, 0)) != -1);
    202       1.1      manu 
    203       1.1      manu 	ATF_REQUIRE(faccessat(dfd, BASEFILE, W_OK, 0) == 0);
    204       1.1      manu 
    205       1.1      manu 	ATF_REQUIRE(fchmod(dfd, 644) == 0);
    206       1.1      manu 
    207       1.1      manu 	ATF_REQUIRE(faccessat(dfd, BASEFILE, W_OK, 0) == 0);
    208       1.1      manu 
    209       1.1      manu 	ATF_REQUIRE(fchmod(dfd, 444) == 0);
    210       1.1      manu 
    211       1.1      manu 	ATF_REQUIRE(faccessat(dfd, BASEFILE, W_OK, 0) == 0);
    212       1.1      manu 
    213       1.1      manu 	ATF_REQUIRE(close(dfd) == 0);
    214       1.1      manu }
    215       1.1      manu 
    216       1.4      jmmv ATF_TC(o_search_unpriv_flag2);
    217       1.2    martin ATF_TC_HEAD(o_search_unpriv_flag2, tc)
    218       1.2    martin {
    219       1.2    martin 	atf_tc_set_md_var(tc, "descr", "See that fstatat honours O_SEARCH");
    220       1.2    martin 	atf_tc_set_md_var(tc, "require.user", "unprivileged");
    221       1.2    martin }
    222       1.2    martin ATF_TC_BODY(o_search_unpriv_flag2, tc)
    223       1.2    martin {
    224       1.2    martin 	int dfd;
    225       1.2    martin 	int fd;
    226       1.2    martin 
    227       1.2    martin 	ATF_REQUIRE(mkdir(DIR, 0755) == 0);
    228       1.2    martin 	ATF_REQUIRE((fd = open(FILE, O_CREAT|O_RDWR, 0644)) != -1);
    229       1.2    martin 	ATF_REQUIRE(close(fd) == 0);
    230       1.2    martin 
    231       1.2    martin 	ATF_REQUIRE((dfd = open(DIR, O_RDONLY|O_SEARCH, 0)) != -1);
    232       1.2    martin 
    233       1.2    martin 	ATF_REQUIRE(faccessat(dfd, BASEFILE, W_OK, 0) == 0);
    234       1.2    martin 
    235       1.3  dholland 	ATF_REQUIRE(fchmod(dfd, 644) == 0);
    236       1.2    martin 
    237       1.2    martin 	ATF_REQUIRE(faccessat(dfd, BASEFILE, W_OK, 0) == 0);
    238       1.2    martin 
    239       1.2    martin 	ATF_REQUIRE(fchmod(dfd, 444) == 0);
    240       1.2    martin 
    241       1.2    martin 	ATF_REQUIRE(faccessat(dfd, BASEFILE, W_OK, 0) == 0);
    242       1.2    martin 
    243       1.2    martin 	ATF_REQUIRE(close(dfd) == 0);
    244       1.2    martin }
    245       1.2    martin 
    246       1.3  dholland #endif /* USE_O_SEARCH */
    247       1.3  dholland 
    248       1.1      manu 
    249       1.4      jmmv ATF_TC(o_search_notdir);
    250       1.1      manu ATF_TC_HEAD(o_search_notdir, tc)
    251       1.1      manu {
    252       1.1      manu 	atf_tc_set_md_var(tc, "descr", "See that openat fails with non dir fd");
    253       1.1      manu }
    254       1.1      manu ATF_TC_BODY(o_search_notdir, tc)
    255       1.1      manu {
    256       1.1      manu 	int dfd;
    257       1.1      manu 	int fd;
    258       1.1      manu 
    259       1.1      manu 	ATF_REQUIRE(mkdir(DIR, 0755) == 0);
    260       1.1      manu 	ATF_REQUIRE((dfd = open(FILE, O_CREAT|O_RDWR|O_SEARCH, 0644)) != -1);
    261       1.1      manu 	ATF_REQUIRE((fd = openat(dfd, BASEFILE, O_RDWR, 0)) == -1);
    262       1.1      manu 	ATF_REQUIRE(errno == ENOTDIR);
    263       1.1      manu }
    264       1.1      manu 
    265       1.1      manu ATF_TP_ADD_TCS(tp)
    266       1.1      manu {
    267       1.1      manu 
    268       1.1      manu 	ATF_TP_ADD_TC(tp, o_search_perm1);
    269       1.3  dholland #ifdef USE_O_SEARCH
    270       1.2    martin 	ATF_TP_ADD_TC(tp, o_search_root_flag1);
    271       1.2    martin 	ATF_TP_ADD_TC(tp, o_search_unpriv_flag1);
    272       1.3  dholland #endif
    273       1.1      manu 	ATF_TP_ADD_TC(tp, o_search_perm2);
    274       1.3  dholland #ifdef USE_O_SEARCH
    275       1.2    martin 	ATF_TP_ADD_TC(tp, o_search_root_flag2);
    276       1.2    martin 	ATF_TP_ADD_TC(tp, o_search_unpriv_flag2);
    277       1.3  dholland #endif
    278       1.1      manu 	ATF_TP_ADD_TC(tp, o_search_notdir);
    279       1.1      manu 
    280       1.1      manu 	return atf_no_error();
    281       1.1      manu }
    282