From e8796490a61a3c7b4ac21b98ebce7008cb4f741a Mon Sep 17 00:00:00 2001
From: Moe Jette <jette1@llnl.gov>
Date: Thu, 27 Mar 2003 22:19:28 +0000
Subject: [PATCH] Added new security test program.

---
 testsuite/slurm_unit/slurmctld/Makefile.am    | 31 +++++++-------
 testsuite/slurm_unit/slurmctld/security_2_4.c | 40 +++++++++++++++++++
 2 files changed, 57 insertions(+), 14 deletions(-)
 create mode 100644 testsuite/slurm_unit/slurmctld/security_2_4.c

diff --git a/testsuite/slurm_unit/slurmctld/Makefile.am b/testsuite/slurm_unit/slurmctld/Makefile.am
index a8fbe1361b1..f66974279e6 100644
--- a/testsuite/slurm_unit/slurmctld/Makefile.am
+++ b/testsuite/slurm_unit/slurmctld/Makefile.am
@@ -1,7 +1,12 @@
 AUTOMAKE_OPTIONS = foreign
 
 noinst_HEADERS = get_resp.h
+
+TESTS =
+#	job_mgr-test 
+
 check_PROGRAMS = \
+	security_2_4 \
 	$(TESTS) 
 #
 # None of these tests can be compiled until functions called
@@ -16,8 +21,6 @@ check_PROGRAMS = \
 #	step_create
 #	
 
-TESTS =
-#	job_mgr-test 
 
 
 INCLUDES = -I$(top_srcdir) -I$(top_srcdir)/src/common
@@ -39,19 +42,19 @@ INCLUDES = -I$(top_srcdir) -I$(top_srcdir)/src/common
 #		$(top_builddir)/src/api/libslurm.la
 
 LDADD  = $(top_builddir)/src/common/libcommon.la \
-		$(top_builddir)/src/common/libhostlist.la	\
-		$(top_builddir)/src/slurmctld/agent.o \
-		$(top_builddir)/src/slurmctld/job_scheduler.o \
-		$(top_builddir)/src/slurmctld/node_scheduler.o \
-		$(top_builddir)/src/slurmctld/partition_mgr.o \
-		$(top_builddir)/src/slurmctld/step_mgr.o \
-		$(top_builddir)/src/slurmctld/job_mgr.o \
-		$(top_builddir)/src/slurmctld/node_mgr.o \
-		$(top_builddir)/src/slurmctld/locks.o \
-		$(top_builddir)/src/slurmctld/read_config.o \
-		$(top_builddir)/src/common/parse_spec.o  \
-		$(top_builddir)/src/api/libslurm.la \
+		$(top_builddir)/src/api/libslurm.la
 		$(SSL_LIBS)
+#		$(top_builddir)/src/common/libhostlist.la	\
+#		$(top_builddir)/src/slurmctld/agent.o \
+#		$(top_builddir)/src/slurmctld/job_scheduler.o \
+#		$(top_builddir)/src/slurmctld/node_scheduler.o \
+#		$(top_builddir)/src/slurmctld/partition_mgr.o \
+#		$(top_builddir)/src/slurmctld/step_mgr.o \
+#		$(top_builddir)/src/slurmctld/job_mgr.o \
+#		$(top_builddir)/src/slurmctld/node_mgr.o \
+#		$(top_builddir)/src/slurmctld/locks.o \
+#		$(top_builddir)/src/slurmctld/read_config.o \
+#		$(top_builddir)/src/common/parse_spec.o  \
 
 force :
 $(LDADD) : force
diff --git a/testsuite/slurm_unit/slurmctld/security_2_4.c b/testsuite/slurm_unit/slurmctld/security_2_4.c
new file mode 100644
index 00000000000..2217a2ffaed
--- /dev/null
+++ b/testsuite/slurm_unit/slurmctld/security_2_4.c
@@ -0,0 +1,40 @@
+#include <errno.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <sys/types.h>
+#include <unistd.h>
+
+#include <slurm/slurm.h>
+#include <slurm/slurm_errno.h>
+
+/* Attempt to run a job with the incorrect user id and confirm an error */
+int 
+main (int argc, char *argv[])
+{
+	int error_code;
+	job_desc_msg_t job_mesg;
+	resource_allocation_and_run_response_msg_t* run_resp_msg ;
+
+	slurm_init_job_desc_msg( &job_mesg );
+	job_mesg. user_id	= getuid() + 1;
+	job_mesg. min_nodes	= 1;
+
+	error_code = slurm_allocate_resources_and_run ( &job_mesg , 
+							&run_resp_msg ); 
+	if (error_code == SLURM_SUCCESS) {
+		fprintf (stderr, "ERROR: The allocate succeeded\n");
+		exit(1);
+	} else if ((error_code = slurm_get_errno()) != ESLURM_USER_ID_MISSING) {
+		fprintf (stderr, 
+			 "ERROR: Wrong error code received %d instead of %d\n",
+			 error_code, ESLURM_USER_ID_MISSING);
+		exit(1);
+
+	} else {
+		printf ("SUCCESS!\n");
+		printf ("The allocate request was rejected as expected.\n");
+		printf ("Check SlurmctldLog for an error message.\n");
+		exit(0);
+	}
+}
+
-- 
GitLab