* @copyright 2013 Andreas Fischer * @license http://www.opensource.org/licenses/mit-license.html MIT License */ declare(strict_types=1); namespace phpseclib3\Tests; use PHPUnit\Framework\TestCase; abstract class PhpseclibTestCase extends TestCase { protected $tempFilesToUnlinkOnTearDown = []; public function tearDown(): void { foreach ($this->tempFilesToUnlinkOnTearDown as $filename) { if (!file_exists($filename) || unlink($filename)) { unset($this->tempFilesToUnlinkOnTearDown[$filename]); } } parent::tearDown(); } /** * Creates a temporary file on the local filesystem and returns its path. * The $number_of_writes and $bytes_per_write parameters can be used to * write $number_of_writes * $bytes_per_write times the character 'a' to the * temporary file. All files created using this method will be deleted from * the filesystem on tearDown(), i.e. after each test method was run. */ protected function createTempFile(int $number_of_writes = 0, int $bytes_per_write = 0): string { $filename = tempnam(sys_get_temp_dir(), 'phpseclib-test-'); $this->assertTrue(file_exists($filename)); $this->tempFilesToUnlinkOnTearDown[] = $filename; if ($number_of_writes > 0 && $bytes_per_write > 0) { $fp = fopen($filename, 'wb'); for ($i = 0; $i < $number_of_writes; ++$i) { fwrite($fp, str_repeat('a', $bytes_per_write)); } fclose($fp); $this->assertSame($number_of_writes * $bytes_per_write, filesize($filename)); } return $filename; } /** * @return null */ protected static function ensureConstant(string $constant, $expected) { if (defined($constant)) { $value = constant($constant); if ($value !== $expected) { if (extension_loaded('runkit')) { if (!runkit_constant_redefine($constant, $expected)) { self::markTestSkipped(sprintf( "Failed to redefine constant %s to %s", $constant, $expected )); } } else { self::markTestSkipped(sprintf( "Skipping test because constant %s is %s instead of %s", $constant, $value, $expected )); } } } else { define($constant, $expected); } } protected static function getVar($obj, $var) { $reflection = new \ReflectionClass($obj::class); $prop = $reflection->getProperty($var); $prop->setAccessible(true); return $prop->getValue($obj); } public static function callFunc($obj, $func, $params = []) { $reflection = new \ReflectionClass($obj::class); $method = $reflection->getMethod($func); $method->setAccessible(true); return $method->invokeArgs($obj, $params); } // assertIsArray was not introduced until PHPUnit 8 public static function assertIsArray($actual, string $message = ''): void { parent::assertInternalType('array', $actual, $message); } // assertIsString was not introduced until PHPUnit 8 public static function assertIsString($actual, string $message = ''): void { parent::assertInternalType('string', $actual, $message); } // assertIsResource was not introduced until PHPUnit 8 public static function assertIsResource($actual, string $message = ''): void { parent::assertInternalType('resource', $actual, $message); } // assertIsObject was not introduced until PHPUnit 8 public static function assertIsObject($actual, string $message = ''): void { parent::assertInternalType('object', $actual, $message); } // assertContains is deprecated for strings in PHPUnit 8 public static function assertStringContainsString(string $needle, string $haystack, string $message = ''): void { parent::assertContains($needle, $haystack, $message); } // assertNotContains is deprecated for strings in PHPUnit 8 public static function assertStringNotContainsString(string $needle, string $haystack, string $message = ''): void { parent::assertNotContains($needle, $haystack, $message); } /** * assertRegExp() was deprecated in favor of assertMatchesRegularExpression(). */ public static function assertMatchesRegularExpression(string $pattern, string $string, string $message = ''): void { parent::assertRegExp($pattern, $string, $message); } }