tests: Check (mcron redirect)
* tests/redirect.scm: New file. * Makefile.am (TESTS): Register it. * src/mcron/redirect.scm (with-mail-out): Adapt to facilitate testing.
This commit is contained in:
		
					parent
					
						
							
								92a940cca5
							
						
					
				
			
			
				commit
				
					
						765bfbf4d9
					
				
			
		
					 3 changed files with 62 additions and 4 deletions
				
			
		| 
						 | 
					@ -137,6 +137,7 @@ TESTS = \
 | 
				
			||||||
  tests/base.scm \
 | 
					  tests/base.scm \
 | 
				
			||||||
  tests/environment.scm \
 | 
					  tests/environment.scm \
 | 
				
			||||||
  tests/job-specifier.scm \
 | 
					  tests/job-specifier.scm \
 | 
				
			||||||
 | 
					  tests/redirect.scm \
 | 
				
			||||||
  tests/utils.scm \
 | 
					  tests/utils.scm \
 | 
				
			||||||
  tests/vixie-specification.scm \
 | 
					  tests/vixie-specification.scm \
 | 
				
			||||||
  tests/vixie-time.scm
 | 
					  tests/vixie-time.scm
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,5 +1,6 @@
 | 
				
			||||||
;;;; redirect.scm -- modify job outputs
 | 
					;;;; redirect.scm -- modify job outputs
 | 
				
			||||||
;;; Copyright © 2003 Dale Mellor <dale_mellor@users.sourceforge.net>
 | 
					;;; Copyright © 2003 Dale Mellor <dale_mellor@users.sourceforge.net>
 | 
				
			||||||
 | 
					;;; Copyright © 2020 Mathieu Lirzin <mthl@gnu.org>
 | 
				
			||||||
;;; Copyright © 2018 宋文武 <iyzsong@member.fsf.org>
 | 
					;;; Copyright © 2018 宋文武 <iyzsong@member.fsf.org>
 | 
				
			||||||
;;;
 | 
					;;;
 | 
				
			||||||
;;; This file is part of GNU Mcron.
 | 
					;;; This file is part of GNU Mcron.
 | 
				
			||||||
| 
						 | 
					@ -63,7 +64,10 @@
 | 
				
			||||||
;; the string, and output (including the error output) being sent to a pipe
 | 
					;; the string, and output (including the error output) being sent to a pipe
 | 
				
			||||||
;; opened on a mail transport.
 | 
					;; opened on a mail transport.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
(define (with-mail-out action . user)
 | 
					(define* (with-mail-out action #:optional user #:key
 | 
				
			||||||
 | 
					                        (hostname (gethostname))
 | 
				
			||||||
 | 
					                        (out (lambda ()
 | 
				
			||||||
 | 
					                               (open-output-pipe config-sendmail))))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  ;; Determine the name of the user who is to recieve the mail, looking for a
 | 
					  ;; Determine the name of the user who is to recieve the mail, looking for a
 | 
				
			||||||
  ;; name in the optional user argument, then in the MAILTO environment
 | 
					  ;; name in the optional user argument, then in the MAILTO environment
 | 
				
			||||||
| 
						 | 
					@ -72,7 +76,7 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  (let* ((mailto (getenv "MAILTO"))
 | 
					  (let* ((mailto (getenv "MAILTO"))
 | 
				
			||||||
         (user (cond (mailto mailto)
 | 
					         (user (cond (mailto mailto)
 | 
				
			||||||
                     ((not (null? user)) (car user))
 | 
					                     (user user)
 | 
				
			||||||
                     (else (getenv "LOGNAME"))))
 | 
					                     (else (getenv "LOGNAME"))))
 | 
				
			||||||
         (parent->child (pipe))
 | 
					         (parent->child (pipe))
 | 
				
			||||||
         (child->parent (pipe))
 | 
					         (child->parent (pipe))
 | 
				
			||||||
| 
						 | 
					@ -173,11 +177,11 @@
 | 
				
			||||||
                                       (open-output-file "/dev/null")
 | 
					                                       (open-output-file "/dev/null")
 | 
				
			||||||
                                       ;; The sendmail command should read
 | 
					                                       ;; The sendmail command should read
 | 
				
			||||||
                                       ;; recipients from the message header.
 | 
					                                       ;; recipients from the message header.
 | 
				
			||||||
                                       (open-output-pipe config-sendmail)))
 | 
					                                       (out)))
 | 
				
			||||||
          (set-current-input-port (car child->parent))
 | 
					          (set-current-input-port (car child->parent))
 | 
				
			||||||
          (display "To: ") (display user) (newline)
 | 
					          (display "To: ") (display user) (newline)
 | 
				
			||||||
          (display "From: mcron") (newline)
 | 
					          (display "From: mcron") (newline)
 | 
				
			||||||
          (display (string-append "Subject: " user "@" (gethostname)))
 | 
					          (display (string-append "Subject: " user "@" hostname))
 | 
				
			||||||
          (newline)
 | 
					          (newline)
 | 
				
			||||||
          (newline)
 | 
					          (newline)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										53
									
								
								tests/redirect.scm
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								tests/redirect.scm
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,53 @@
 | 
				
			||||||
 | 
					;;;; redirect.scm -- tests for (mcron redirect) module
 | 
				
			||||||
 | 
					;;; Copyright © 2020 Mathieu Lirzin <mthl@gnu.org>
 | 
				
			||||||
 | 
					;;;
 | 
				
			||||||
 | 
					;;; This file is part of GNU Mcron.
 | 
				
			||||||
 | 
					;;;
 | 
				
			||||||
 | 
					;;; GNU Mcron is free software: you can redistribute it and/or modify
 | 
				
			||||||
 | 
					;;; it under the terms of the GNU General Public License as published by
 | 
				
			||||||
 | 
					;;; the Free Software Foundation, either version 3 of the License, or
 | 
				
			||||||
 | 
					;;; (at your option) any later version.
 | 
				
			||||||
 | 
					;;;
 | 
				
			||||||
 | 
					;;; GNU Mcron is distributed in the hope that it will be useful,
 | 
				
			||||||
 | 
					;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
				
			||||||
 | 
					;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
				
			||||||
 | 
					;;; GNU General Public License for more details.
 | 
				
			||||||
 | 
					;;;
 | 
				
			||||||
 | 
					;;; You should have received a copy of the GNU General Public License
 | 
				
			||||||
 | 
					;;; along with GNU Mcron.  If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(use-modules (ice-9 textual-ports)
 | 
				
			||||||
 | 
					             (srfi srfi-1)
 | 
				
			||||||
 | 
					             (srfi srfi-64)
 | 
				
			||||||
 | 
					             (mcron redirect))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(setenv "TZ" "UTC0")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(test-begin "redirect")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(define out (mkstemp! (string-copy "foo-XXXXXX")))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(dynamic-wind
 | 
				
			||||||
 | 
					  (const #t)
 | 
				
			||||||
 | 
					  (lambda ()
 | 
				
			||||||
 | 
					    (with-mail-out "echo 'foo'" "user0"
 | 
				
			||||||
 | 
					                   #:out (lambda () out)
 | 
				
			||||||
 | 
					                   #:hostname "localhost")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    (flush-all-ports)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    (test-equal "mail output"
 | 
				
			||||||
 | 
					      "To: user0
 | 
				
			||||||
 | 
					From: mcron
 | 
				
			||||||
 | 
					Subject: user0@localhost
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					foo
 | 
				
			||||||
 | 
					"
 | 
				
			||||||
 | 
					      (call-with-input-file (port-filename out) get-string-all)))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  (lambda ()
 | 
				
			||||||
 | 
					    (let ((fname (port-filename out)))
 | 
				
			||||||
 | 
					      (close out)
 | 
				
			||||||
 | 
					      (delete-file fname))))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					(test-end)
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue