diff options
author | Morris Jobke <hey@morrisjobke.de> | 2015-09-24 17:01:31 +0200 |
---|---|---|
committer | Morris Jobke <hey@morrisjobke.de> | 2015-09-24 20:01:30 +0200 |
commit | db8e7ce8b95c882c876f932296f25ec08883a1d3 (patch) | |
tree | 807952698b4a0704172285f989563ac572df2762 /tests | |
parent | 846b8268672df2c626616fec5f71e15570005e84 (diff) | |
download | nextcloud-server-db8e7ce8b95c882c876f932296f25ec08883a1d3.tar.gz nextcloud-server-db8e7ce8b95c882c876f932296f25ec08883a1d3.zip |
Remove passwords from logged exception stack traces
* fixed #16318
* create logException in ILogger
* add unit tests
Diffstat (limited to 'tests')
-rw-r--r-- | tests/lib/logger.php | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/tests/lib/logger.php b/tests/lib/logger.php index c8566988cf4..9c9cd9e6728 100644 --- a/tests/lib/logger.php +++ b/tests/lib/logger.php @@ -63,4 +63,48 @@ class Logger extends TestCase { public static function write($app, $message, $level) { self::$logs[]= "$level $message"; } + + public function userAndPasswordData() { + return [ + ['abc', 'def'], + ['mySpecialUsername', 'MySuperSecretPassword'], + ['my-user', '324324()#รค234'], + ['my-user', ')qwer'], + ['my-user', 'qwer)asdf'], + ['my-user', 'qwer)'], + ['my-user', '(qwer'], + ['my-user', 'qwer(asdf'], + ['my-user', 'qwer('], + ]; + } + + /** + * @dataProvider userAndPasswordData + */ + public function testDetectlogin($user, $password) { + $e = new \Exception('test'); + $this->logger->logException($e); + + $logLines = $this->getLogs(); + foreach($logLines as $logLine) { + $this->assertNotContains($user, $logLine); + $this->assertNotContains($password, $logLine); + $this->assertContains('login(*** username and password replaced ***)', $logLine); + } + } + + /** + * @dataProvider userAndPasswordData + */ + public function testDetectcheckPassword($user, $password) { + $e = new \Exception('test'); + $this->logger->logException($e); + $logLines = $this->getLogs(); + + foreach($logLines as $logLine) { + $this->assertNotContains($user, $logLine); + $this->assertNotContains($password, $logLine); + $this->assertContains('checkPassword(*** username and password replaced ***)', $logLine); + } + } } |