| 
									
										
										
										
											2016-01-20 20:49:23 +00:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2019-11-28 20:18:25 +00:00
										 |  |  | use PHPUnit\Framework\TestCase; | 
					
						
							| 
									
										
										
										
											2016-01-20 20:49:23 +00:00
										 |  |  | /* | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/) | 
					
						
							| 
									
										
										
										
											2019-11-28 20:18:25 +00:00
										 |  |  |  Copyright (C) 2016 - 2019  Roland Gruber | 
					
						
							| 
									
										
										
										
											2016-01-20 20:49:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |  This program 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 2 of the License, or | 
					
						
							|  |  |  |  (at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  This program 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 this program; if not, write to the Free Software | 
					
						
							|  |  |  |  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 	include_once 'lam/lib/baseModule.inc'; | 
					
						
							|  |  |  | 	include_once 'lam/lib/modules.inc'; | 
					
						
							| 
									
										
										
										
											2017-10-16 17:51:27 +00:00
										 |  |  | 	if (is_readable('lam/lib/passwordExpirationJob.inc')) { | 
					
						
							|  |  |  | 		include_once 'lam/lib/passwordExpirationJob.inc'; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 	include_once 'lam/lib/modules/shadowAccount.inc'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-16 17:51:27 +00:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Checks the shadowAccount class. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @author Roland Gruber | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2019-11-28 20:18:25 +00:00
										 |  |  | 	class ShadowAccountTest extends TestCase { | 
					
						
							| 
									
										
										
										
											2017-10-16 17:51:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		public function test_isAccountExpired_noAttr() { | 
					
						
							|  |  |  | 			$attrs = array('objectClass' => array('shadowAccount')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->assertFalse(shadowAccount::isAccountExpired($attrs)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function test_isAccountExpired_notExpired() { | 
					
						
							|  |  |  | 			$expire = intval(time() / (24*3600)) + 10000; | 
					
						
							|  |  |  | 			$attrs = array( | 
					
						
							|  |  |  | 				'objectClass' => array('shadowAccount'), | 
					
						
							|  |  |  | 				'sHadoweXpirE' => array(0 => $expire) | 
					
						
							|  |  |  | 			); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->assertFalse(shadowAccount::isAccountExpired($attrs)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function test_isAccountExpired_expired() { | 
					
						
							|  |  |  | 			$expire = intval(time() / (24*3600)) - 10000; | 
					
						
							|  |  |  | 			$attrs = array( | 
					
						
							|  |  |  | 				'objectClass' => array('shadowAccount'), | 
					
						
							|  |  |  | 				'sHadoweXpirE' => array(0 => $expire) | 
					
						
							|  |  |  | 			); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->assertTrue(shadowAccount::isAccountExpired($attrs)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-17 15:46:04 +00:00
										 |  |  | 		public function test_isPasswordExpired_noAttr() { | 
					
						
							|  |  |  | 			$attrs = array('objectClass' => array('shadowAccount')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->assertFalse(shadowAccount::isPasswordExpired($attrs)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function test_isPasswordExpired_notExpired() { | 
					
						
							|  |  |  | 			$change = intval(time() / (24*3600)) - 10; | 
					
						
							|  |  |  | 			$attrs = array( | 
					
						
							|  |  |  | 				'objectClass' => array('shadowAccount'), | 
					
						
							|  |  |  | 				'shadoWlastCHange' => array(0 => $change), | 
					
						
							|  |  |  | 				'shadowmax' => array(0 => '14'), | 
					
						
							|  |  |  | 			); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->assertFalse(shadowAccount::isPasswordExpired($attrs)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function test_isPasswordExpired_expired() { | 
					
						
							|  |  |  | 			$change = intval(time() / (24*3600)) - 10; | 
					
						
							|  |  |  | 			$attrs = array( | 
					
						
							|  |  |  | 				'objectClass' => array('shadowAccount'), | 
					
						
							|  |  |  | 				'shadoWlastCHange' => array(0 => $change), | 
					
						
							|  |  |  | 				'shadowmax' => array(0 => '7'), | 
					
						
							|  |  |  | 			); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->assertTrue(shadowAccount::isPasswordExpired($attrs)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function test_isPasswordExpired_notExpiredInactiveSet() { | 
					
						
							|  |  |  | 			$change = intval(time() / (24*3600)) - 10; | 
					
						
							|  |  |  | 			$attrs = array( | 
					
						
							|  |  |  | 				'objectClass' => array('shadowAccount'), | 
					
						
							|  |  |  | 				'shadoWlastCHange' => array(0 => $change), | 
					
						
							|  |  |  | 				'shadowmax' => array(0 => '7'), | 
					
						
							|  |  |  | 				'shaDowinactIVe' => array(0 => '14'), | 
					
						
							|  |  |  | 			); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->assertFalse(shadowAccount::isPasswordExpired($attrs)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function test_isPasswordExpired_expiredInactiveSet() { | 
					
						
							|  |  |  | 			$change = intval(time() / (24*3600)) - 10; | 
					
						
							|  |  |  | 			$attrs = array( | 
					
						
							|  |  |  | 				'objectClass' => array('shadowAccount'), | 
					
						
							|  |  |  | 				'shadoWlastCHange' => array(0 => $change), | 
					
						
							|  |  |  | 				'shadowmax' => array(0 => '7'), | 
					
						
							|  |  |  | 				'shaDowinactIVe' => array(0 => '2'), | 
					
						
							|  |  |  | 			); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->assertTrue(shadowAccount::isPasswordExpired($attrs)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-16 17:51:27 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (is_readable('lam/lib/passwordExpirationJob.inc')) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Checks the shadow expire job. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @author Roland Gruber | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2019-11-28 20:18:25 +00:00
										 |  |  | 	class ShadowAccountPasswordNotifyJobTest extends TestCase { | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		private $job; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		const JOB_ID = 'jobID'; | 
					
						
							|  |  |  | 		const WARNING = '14'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		private $options = array(); | 
					
						
							| 
									
										
										
										
											2018-05-01 07:34:56 +00:00
										 |  |  | 		private $resultLog = null; | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		public function setUp() { | 
					
						
							|  |  |  | 			$this->job = $this->getMockBuilder('ShadowAccountPasswordNotifyJob') | 
					
						
							|  |  |  | 				->setMethods(array('getDBLastPwdChangeTime', 'setDBLastPwdChangeTime', 'sendMail', 'findUsers', 'getConfigPrefix')) | 
					
						
							|  |  |  | 				->getMock(); | 
					
						
							|  |  |  | 			$this->job->method('getConfigPrefix')->willReturn('test'); | 
					
						
							|  |  |  | 			$this->job->method('sendMail')->willReturn(true); | 
					
						
							|  |  |  | 			$this->options['test_mailNotificationPeriod' . ShadowAccountPasswordNotifyJobTest::JOB_ID][0] = ShadowAccountPasswordNotifyJobTest::WARNING; | 
					
						
							| 
									
										
										
										
											2018-05-01 07:34:56 +00:00
										 |  |  | 			$this->resultLog = new \LAM\JOB\JobResultLog(); | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function testNoAccounts() { | 
					
						
							|  |  |  | 			$this->job->method('findUsers')->willReturn(array()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('setDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('sendMail'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$pdo = array(); | 
					
						
							| 
									
										
										
										
											2018-05-01 07:34:56 +00:00
										 |  |  | 			$this->job->execute(ShadowAccountPasswordNotifyJobTest::JOB_ID, $this->options, $pdo, false, $this->resultLog); | 
					
						
							|  |  |  | 			$this->assertFalse($this->resultLog->hasError()); | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function testAccountDoesNotExpire() { | 
					
						
							|  |  |  | 			$this->job->method('findUsers')->willReturn(array(array( | 
					
						
							|  |  |  | 					'dn' => 'cn=some,dc=dn', | 
					
						
							|  |  |  | 					'shadowmax' => array('0'), | 
					
						
							|  |  |  | 					'shadowlastchange' => array('1') | 
					
						
							|  |  |  | 			))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('setDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('sendMail'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$pdo = array(); | 
					
						
							| 
									
										
										
										
											2018-05-01 07:34:56 +00:00
										 |  |  | 			$this->job->execute(ShadowAccountPasswordNotifyJobTest::JOB_ID, $this->options, $pdo, false, $this->resultLog); | 
					
						
							|  |  |  | 			$this->assertFalse($this->resultLog->hasError()); | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function testAccountExpired() { | 
					
						
							|  |  |  | 			$this->job->method('findUsers')->willReturn(array(array( | 
					
						
							|  |  |  | 					'dn' => 'cn=some,dc=dn', | 
					
						
							|  |  |  | 					'shadowmax' => array('10'), | 
					
						
							|  |  |  | 					'shadowlastchange' => array('1') | 
					
						
							|  |  |  | 			))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('setDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('sendMail'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$pdo = array(); | 
					
						
							| 
									
										
										
										
											2018-05-01 07:34:56 +00:00
										 |  |  | 			$this->job->execute(ShadowAccountPasswordNotifyJobTest::JOB_ID, $this->options, $pdo, false, $this->resultLog); | 
					
						
							|  |  |  | 			$this->assertFalse($this->resultLog->hasError()); | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function testWarningNotReached() { | 
					
						
							|  |  |  | 			$now = new DateTime('now', getTimeZone()); | 
					
						
							|  |  |  | 			$lastChangeNow = floor($now->format('U')/3600/24); | 
					
						
							|  |  |  | 			$this->job->method('getDBLastPwdChangeTime')->willReturn($lastChangeNow); | 
					
						
							|  |  |  | 			$this->job->method('findUsers')->willReturn(array(array( | 
					
						
							|  |  |  | 					'dn' => 'cn=some,dc=dn', | 
					
						
							|  |  |  | 					'shadowmax' => array('300'), | 
					
						
							|  |  |  | 					'shadowlastchange' => array($lastChangeNow) | 
					
						
							|  |  |  | 			))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('setDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('sendMail'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$pdo = array(); | 
					
						
							| 
									
										
										
										
											2018-05-01 07:34:56 +00:00
										 |  |  | 			$this->job->execute(ShadowAccountPasswordNotifyJobTest::JOB_ID, $this->options, $pdo, false, $this->resultLog); | 
					
						
							|  |  |  | 			$this->assertFalse($this->resultLog->hasError()); | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function testAlreadyWarned() { | 
					
						
							|  |  |  | 			$now = new DateTime('now', getTimeZone()); | 
					
						
							|  |  |  | 			$lastChangeNow = floor($now->format('U')/3600/24); | 
					
						
							|  |  |  | 			$this->job->method('getDBLastPwdChangeTime')->willReturn($lastChangeNow); | 
					
						
							|  |  |  | 			$this->job->method('findUsers')->willReturn(array(array( | 
					
						
							|  |  |  | 					'dn' => 'cn=some,dc=dn', | 
					
						
							|  |  |  | 					'shadowmax' => array('10'), | 
					
						
							|  |  |  | 					'shadowlastchange' => array($lastChangeNow) | 
					
						
							|  |  |  | 			))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->job->expects($this->once())->method('getDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('setDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('sendMail'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$pdo = array(); | 
					
						
							| 
									
										
										
										
											2018-05-01 07:34:56 +00:00
										 |  |  | 			$this->job->execute(ShadowAccountPasswordNotifyJobTest::JOB_ID, $this->options, $pdo, false, $this->resultLog); | 
					
						
							|  |  |  | 			$this->assertFalse($this->resultLog->hasError()); | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function testWarning() { | 
					
						
							|  |  |  | 			$now = new DateTime('now', getTimeZone()); | 
					
						
							|  |  |  | 			$lastChangeNow = floor($now->format('U')/3600/24); | 
					
						
							|  |  |  | 			$this->job->method('getDBLastPwdChangeTime')->willReturn('1'); | 
					
						
							|  |  |  | 			$this->job->method('findUsers')->willReturn(array(array( | 
					
						
							|  |  |  | 					'dn' => 'cn=some,dc=dn', | 
					
						
							|  |  |  | 					'shadowmax' => array('10'), | 
					
						
							|  |  |  | 					'shadowlastchange' => array($lastChangeNow) | 
					
						
							|  |  |  | 			))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->job->expects($this->once())->method('getDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->once())->method('setDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->once())->method('sendMail'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$pdo = array(); | 
					
						
							| 
									
										
										
										
											2018-05-01 07:34:56 +00:00
										 |  |  | 			$this->job->execute(ShadowAccountPasswordNotifyJobTest::JOB_ID, $this->options, $pdo, false, $this->resultLog); | 
					
						
							|  |  |  | 			$this->assertFalse($this->resultLog->hasError()); | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		public function testWarningDryRun() { | 
					
						
							|  |  |  | 			$now = new DateTime('now', getTimeZone()); | 
					
						
							|  |  |  | 			$lastChangeNow = floor($now->format('U')/3600/24); | 
					
						
							|  |  |  | 			$this->job->method('getDBLastPwdChangeTime')->willReturn('1'); | 
					
						
							|  |  |  | 			$this->job->method('findUsers')->willReturn(array(array( | 
					
						
							|  |  |  | 					'dn' => 'cn=some,dc=dn', | 
					
						
							|  |  |  | 					'shadowmax' => array('10'), | 
					
						
							|  |  |  | 					'shadowlastchange' => array($lastChangeNow) | 
					
						
							|  |  |  | 			))); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$this->job->expects($this->once())->method('getDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('setDBLastPwdChangeTime'); | 
					
						
							|  |  |  | 			$this->job->expects($this->never())->method('sendMail'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			$pdo = array(); | 
					
						
							| 
									
										
										
										
											2018-05-01 07:34:56 +00:00
										 |  |  | 			$this->job->execute(ShadowAccountPasswordNotifyJobTest::JOB_ID, $this->options, $pdo, true, $this->resultLog); | 
					
						
							|  |  |  | 			$this->assertFalse($this->resultLog->hasError()); | 
					
						
							| 
									
										
										
										
											2016-12-26 17:16:49 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-01-20 20:49:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-19 17:32:22 +00:00
										 |  |  | ?>
 |