1*23d17223SDag-Erling Smørgrav /*-
2*23d17223SDag-Erling Smørgrav * Copyright (c) 2019 Dag-Erling Smørgrav
3*23d17223SDag-Erling Smørgrav * All rights reserved.
4*23d17223SDag-Erling Smørgrav *
5*23d17223SDag-Erling Smørgrav * Redistribution and use in source and binary forms, with or without
6*23d17223SDag-Erling Smørgrav * modification, are permitted provided that the following conditions
7*23d17223SDag-Erling Smørgrav * are met:
8*23d17223SDag-Erling Smørgrav * 1. Redistributions of source code must retain the above copyright
9*23d17223SDag-Erling Smørgrav * notice, this list of conditions and the following disclaimer.
10*23d17223SDag-Erling Smørgrav * 2. Redistributions in binary form must reproduce the above copyright
11*23d17223SDag-Erling Smørgrav * notice, this list of conditions and the following disclaimer in the
12*23d17223SDag-Erling Smørgrav * documentation and/or other materials provided with the distribution.
13*23d17223SDag-Erling Smørgrav * 3. The name of the author may not be used to endorse or promote
14*23d17223SDag-Erling Smørgrav * products derived from this software without specific prior written
15*23d17223SDag-Erling Smørgrav * permission.
16*23d17223SDag-Erling Smørgrav *
17*23d17223SDag-Erling Smørgrav * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
18*23d17223SDag-Erling Smørgrav * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19*23d17223SDag-Erling Smørgrav * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20*23d17223SDag-Erling Smørgrav * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
21*23d17223SDag-Erling Smørgrav * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22*23d17223SDag-Erling Smørgrav * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23*23d17223SDag-Erling Smørgrav * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24*23d17223SDag-Erling Smørgrav * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25*23d17223SDag-Erling Smørgrav * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26*23d17223SDag-Erling Smørgrav * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27*23d17223SDag-Erling Smørgrav * SUCH DAMAGE.
28*23d17223SDag-Erling Smørgrav */
29*23d17223SDag-Erling Smørgrav
30*23d17223SDag-Erling Smørgrav #ifdef HAVE_CONFIG_H
31*23d17223SDag-Erling Smørgrav # include "config.h"
32*23d17223SDag-Erling Smørgrav #endif
33*23d17223SDag-Erling Smørgrav
34*23d17223SDag-Erling Smørgrav #include <stdint.h>
35*23d17223SDag-Erling Smørgrav #include <stdio.h>
36*23d17223SDag-Erling Smørgrav #include <unistd.h>
37*23d17223SDag-Erling Smørgrav
38*23d17223SDag-Erling Smørgrav #include <cryb/test.h>
39*23d17223SDag-Erling Smørgrav
40*23d17223SDag-Erling Smørgrav #include <security/pam_appl.h>
41*23d17223SDag-Erling Smørgrav #include <security/openpam.h>
42*23d17223SDag-Erling Smørgrav
43*23d17223SDag-Erling Smørgrav #include "t_pam_err.h"
44*23d17223SDag-Erling Smørgrav
45*23d17223SDag-Erling Smørgrav #define T_ENV_NAME "MAGIC_WORDS"
46*23d17223SDag-Erling Smørgrav #define T_ENV_VALUE "SQUEAMISH OSSIFRAGE"
47*23d17223SDag-Erling Smørgrav #define T_ENV_NAMEVALUE T_ENV_NAME "=" T_ENV_VALUE
48*23d17223SDag-Erling Smørgrav
49*23d17223SDag-Erling Smørgrav struct pam_conv t_null_pamc;
50*23d17223SDag-Erling Smørgrav
51*23d17223SDag-Erling Smørgrav
52*23d17223SDag-Erling Smørgrav /***************************************************************************
53*23d17223SDag-Erling Smørgrav * Tests
54*23d17223SDag-Erling Smørgrav */
55*23d17223SDag-Erling Smørgrav
56*23d17223SDag-Erling Smørgrav static int
t_env_empty(char ** desc CRYB_UNUSED,void * arg CRYB_UNUSED)57*23d17223SDag-Erling Smørgrav t_env_empty(char **desc CRYB_UNUSED, void *arg CRYB_UNUSED)
58*23d17223SDag-Erling Smørgrav {
59*23d17223SDag-Erling Smørgrav pam_handle_t *pamh;
60*23d17223SDag-Erling Smørgrav char **envlist;
61*23d17223SDag-Erling Smørgrav int pam_err, ret;
62*23d17223SDag-Erling Smørgrav
63*23d17223SDag-Erling Smørgrav ret = 1;
64*23d17223SDag-Erling Smørgrav pam_err = pam_start("t_pam_env", "test", &t_null_pamc, &pamh);
65*23d17223SDag-Erling Smørgrav t_assert(pam_err == PAM_SUCCESS);
66*23d17223SDag-Erling Smørgrav envlist = pam_getenvlist(pamh);
67*23d17223SDag-Erling Smørgrav ret &= t_is_not_null(envlist);
68*23d17223SDag-Erling Smørgrav if (envlist != NULL) {
69*23d17223SDag-Erling Smørgrav ret &= t_is_null(*envlist);
70*23d17223SDag-Erling Smørgrav openpam_free_envlist(envlist);
71*23d17223SDag-Erling Smørgrav }
72*23d17223SDag-Erling Smørgrav pam_end(pamh, pam_err);
73*23d17223SDag-Erling Smørgrav return (ret);
74*23d17223SDag-Erling Smørgrav }
75*23d17223SDag-Erling Smørgrav
76*23d17223SDag-Erling Smørgrav static int
t_putenv_simple(char ** desc CRYB_UNUSED,void * arg CRYB_UNUSED)77*23d17223SDag-Erling Smørgrav t_putenv_simple(char **desc CRYB_UNUSED, void *arg CRYB_UNUSED)
78*23d17223SDag-Erling Smørgrav {
79*23d17223SDag-Erling Smørgrav pam_handle_t *pamh;
80*23d17223SDag-Erling Smørgrav char **envlist;
81*23d17223SDag-Erling Smørgrav int pam_err, ret;
82*23d17223SDag-Erling Smørgrav
83*23d17223SDag-Erling Smørgrav ret = 1;
84*23d17223SDag-Erling Smørgrav pam_err = pam_start("t_pam_env", "test", &t_null_pamc, &pamh);
85*23d17223SDag-Erling Smørgrav t_assert(pam_err == PAM_SUCCESS);
86*23d17223SDag-Erling Smørgrav pam_err = pam_putenv(pamh, T_ENV_NAMEVALUE);
87*23d17223SDag-Erling Smørgrav ret &= t_compare_pam_err(PAM_SUCCESS, pam_err);
88*23d17223SDag-Erling Smørgrav envlist = pam_getenvlist(pamh);
89*23d17223SDag-Erling Smørgrav ret &= t_is_not_null(envlist);
90*23d17223SDag-Erling Smørgrav if (envlist != NULL) {
91*23d17223SDag-Erling Smørgrav ret &= t_compare_str(T_ENV_NAMEVALUE, envlist[0])
92*23d17223SDag-Erling Smørgrav & t_is_null(envlist[1]);
93*23d17223SDag-Erling Smørgrav openpam_free_envlist(envlist);
94*23d17223SDag-Erling Smørgrav }
95*23d17223SDag-Erling Smørgrav pam_end(pamh, pam_err);
96*23d17223SDag-Erling Smørgrav return (ret);
97*23d17223SDag-Erling Smørgrav }
98*23d17223SDag-Erling Smørgrav
99*23d17223SDag-Erling Smørgrav static int
t_setenv_simple(char ** desc CRYB_UNUSED,void * arg CRYB_UNUSED)100*23d17223SDag-Erling Smørgrav t_setenv_simple(char **desc CRYB_UNUSED, void *arg CRYB_UNUSED)
101*23d17223SDag-Erling Smørgrav {
102*23d17223SDag-Erling Smørgrav pam_handle_t *pamh;
103*23d17223SDag-Erling Smørgrav char **envlist;
104*23d17223SDag-Erling Smørgrav int pam_err, ret;
105*23d17223SDag-Erling Smørgrav
106*23d17223SDag-Erling Smørgrav ret = 1;
107*23d17223SDag-Erling Smørgrav pam_err = pam_start("t_pam_env", "test", &t_null_pamc, &pamh);
108*23d17223SDag-Erling Smørgrav t_assert(pam_err == PAM_SUCCESS);
109*23d17223SDag-Erling Smørgrav pam_err = pam_setenv(pamh, T_ENV_NAME, T_ENV_VALUE, 0);
110*23d17223SDag-Erling Smørgrav ret &= t_compare_pam_err(PAM_SUCCESS, pam_err);
111*23d17223SDag-Erling Smørgrav envlist = pam_getenvlist(pamh);
112*23d17223SDag-Erling Smørgrav ret &= t_is_not_null(envlist);
113*23d17223SDag-Erling Smørgrav if (envlist != NULL) {
114*23d17223SDag-Erling Smørgrav ret &= t_compare_str(T_ENV_NAMEVALUE, envlist[0])
115*23d17223SDag-Erling Smørgrav & t_is_null(envlist[1]);
116*23d17223SDag-Erling Smørgrav openpam_free_envlist(envlist);
117*23d17223SDag-Erling Smørgrav }
118*23d17223SDag-Erling Smørgrav pam_end(pamh, pam_err);
119*23d17223SDag-Erling Smørgrav return (ret);
120*23d17223SDag-Erling Smørgrav }
121*23d17223SDag-Erling Smørgrav
122*23d17223SDag-Erling Smørgrav static int
t_getenv_empty(char ** desc CRYB_UNUSED,void * arg CRYB_UNUSED)123*23d17223SDag-Erling Smørgrav t_getenv_empty(char **desc CRYB_UNUSED, void *arg CRYB_UNUSED)
124*23d17223SDag-Erling Smørgrav {
125*23d17223SDag-Erling Smørgrav pam_handle_t *pamh;
126*23d17223SDag-Erling Smørgrav const char *value;
127*23d17223SDag-Erling Smørgrav int pam_err, ret;
128*23d17223SDag-Erling Smørgrav
129*23d17223SDag-Erling Smørgrav ret = 1;
130*23d17223SDag-Erling Smørgrav pam_err = pam_start("t_pam_env", "test", &t_null_pamc, &pamh);
131*23d17223SDag-Erling Smørgrav t_assert(pam_err == PAM_SUCCESS);
132*23d17223SDag-Erling Smørgrav value = pam_getenv(pamh, T_ENV_NAME);
133*23d17223SDag-Erling Smørgrav ret &= t_compare_str(NULL, value);
134*23d17223SDag-Erling Smørgrav pam_end(pamh, pam_err);
135*23d17223SDag-Erling Smørgrav return (ret);
136*23d17223SDag-Erling Smørgrav }
137*23d17223SDag-Erling Smørgrav
138*23d17223SDag-Erling Smørgrav static int
t_getenv_simple_miss(char ** desc CRYB_UNUSED,void * arg CRYB_UNUSED)139*23d17223SDag-Erling Smørgrav t_getenv_simple_miss(char **desc CRYB_UNUSED, void *arg CRYB_UNUSED)
140*23d17223SDag-Erling Smørgrav {
141*23d17223SDag-Erling Smørgrav pam_handle_t *pamh;
142*23d17223SDag-Erling Smørgrav const char *value;
143*23d17223SDag-Erling Smørgrav int pam_err, ret;
144*23d17223SDag-Erling Smørgrav
145*23d17223SDag-Erling Smørgrav ret = 1;
146*23d17223SDag-Erling Smørgrav pam_err = pam_start("t_pam_env", "test", &t_null_pamc, &pamh);
147*23d17223SDag-Erling Smørgrav t_assert(pam_err == PAM_SUCCESS);
148*23d17223SDag-Erling Smørgrav pam_err = pam_setenv(pamh, T_ENV_NAME, T_ENV_VALUE, 0);
149*23d17223SDag-Erling Smørgrav t_assert(pam_err == PAM_SUCCESS);
150*23d17223SDag-Erling Smørgrav value = pam_getenv(pamh, "XYZZY");
151*23d17223SDag-Erling Smørgrav ret &= t_compare_str(NULL, value);
152*23d17223SDag-Erling Smørgrav pam_end(pamh, pam_err);
153*23d17223SDag-Erling Smørgrav return (ret);
154*23d17223SDag-Erling Smørgrav }
155*23d17223SDag-Erling Smørgrav
156*23d17223SDag-Erling Smørgrav static int
t_getenv_simple_hit(char ** desc CRYB_UNUSED,void * arg CRYB_UNUSED)157*23d17223SDag-Erling Smørgrav t_getenv_simple_hit(char **desc CRYB_UNUSED, void *arg CRYB_UNUSED)
158*23d17223SDag-Erling Smørgrav {
159*23d17223SDag-Erling Smørgrav pam_handle_t *pamh;
160*23d17223SDag-Erling Smørgrav const char *value;
161*23d17223SDag-Erling Smørgrav int pam_err, ret;
162*23d17223SDag-Erling Smørgrav
163*23d17223SDag-Erling Smørgrav ret = 1;
164*23d17223SDag-Erling Smørgrav pam_err = pam_start("t_pam_env", "test", &t_null_pamc, &pamh);
165*23d17223SDag-Erling Smørgrav t_assert(pam_err == PAM_SUCCESS);
166*23d17223SDag-Erling Smørgrav pam_err = pam_setenv(pamh, T_ENV_NAME, T_ENV_VALUE, 0);
167*23d17223SDag-Erling Smørgrav t_assert(pam_err == PAM_SUCCESS);
168*23d17223SDag-Erling Smørgrav value = pam_getenv(pamh, T_ENV_NAME);
169*23d17223SDag-Erling Smørgrav ret &= t_compare_str(T_ENV_VALUE, value);
170*23d17223SDag-Erling Smørgrav pam_end(pamh, pam_err);
171*23d17223SDag-Erling Smørgrav return (ret);
172*23d17223SDag-Erling Smørgrav }
173*23d17223SDag-Erling Smørgrav
174*23d17223SDag-Erling Smørgrav
175*23d17223SDag-Erling Smørgrav /***************************************************************************
176*23d17223SDag-Erling Smørgrav * Boilerplate
177*23d17223SDag-Erling Smørgrav */
178*23d17223SDag-Erling Smørgrav
179*23d17223SDag-Erling Smørgrav static int
t_prepare(int argc CRYB_UNUSED,char * argv[]CRYB_UNUSED)180*23d17223SDag-Erling Smørgrav t_prepare(int argc CRYB_UNUSED, char *argv[] CRYB_UNUSED)
181*23d17223SDag-Erling Smørgrav {
182*23d17223SDag-Erling Smørgrav
183*23d17223SDag-Erling Smørgrav openpam_set_feature(OPENPAM_FALLBACK_TO_OTHER, 0);
184*23d17223SDag-Erling Smørgrav
185*23d17223SDag-Erling Smørgrav t_add_test(t_env_empty, NULL, "initially empty");
186*23d17223SDag-Erling Smørgrav t_add_test(t_putenv_simple, NULL, "put - simple");
187*23d17223SDag-Erling Smørgrav t_add_test(t_setenv_simple, NULL, "set - simple");
188*23d17223SDag-Erling Smørgrav t_add_test(t_getenv_empty, NULL, "get - empty");
189*23d17223SDag-Erling Smørgrav t_add_test(t_getenv_simple_miss, NULL, "get - simple (miss)");
190*23d17223SDag-Erling Smørgrav t_add_test(t_getenv_simple_hit, NULL, "get - simple (hit)");
191*23d17223SDag-Erling Smørgrav
192*23d17223SDag-Erling Smørgrav return (0);
193*23d17223SDag-Erling Smørgrav }
194*23d17223SDag-Erling Smørgrav
195*23d17223SDag-Erling Smørgrav int
main(int argc,char * argv[])196*23d17223SDag-Erling Smørgrav main(int argc, char *argv[])
197*23d17223SDag-Erling Smørgrav {
198*23d17223SDag-Erling Smørgrav
199*23d17223SDag-Erling Smørgrav t_main(t_prepare, NULL, argc, argv);
200*23d17223SDag-Erling Smørgrav }
201