From 92af109e3b7aca8e13df75cace0f653104413d37 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=A6=82=E6=9E=9C=E7=9A=84=E5=A6=82=E6=9E=9C?= Date: Wed, 22 Mar 2023 13:14:55 +0800 Subject: [PATCH] OptionalTest.php --- .../Validator/OptionIfParamNotInArrayTest.php | 193 ++++++++++++++++++ 1 file changed, 193 insertions(+) create mode 100644 tests/Validator/OptionIfParamNotInArrayTest.php diff --git a/tests/Validator/OptionIfParamNotInArrayTest.php b/tests/Validator/OptionIfParamNotInArrayTest.php new file mode 100644 index 0000000..bdd1b84 --- /dev/null +++ b/tests/Validator/OptionIfParamNotInArrayTest.php @@ -0,0 +1,193 @@ +withQueryParams([ + "account"=>"normal", + ]); + + $num = new Param( + name:"num", + validate: [ + new OptionalIfParamValNoInArray("account",[ + 'admin' + ]), + new Integer() + ] + ); + $num->parsedValue($request); + + $account = new Param( + name: "account" + ); + $account->parsedValue($request); + + $allDefineParams = [ + 'account'=>$account, + 'num'=>$num, + ]; + + $ret = true; + $rules = $num->validate; + /** @var AbstractValidator $rule */ + foreach ($rules as $rule){ + $rule->allCheckParams($allDefineParams); + $ret = $rule->execute($num,$request); + if(!$ret){ + break; + } + } + + $this->assertEquals(true,$ret); + } + + function testEmpty() + { + $request = new Request(); + $request->withQueryParams([ + "account"=>"", + ]); + + $num = new Param( + name:"num", + validate: [ + new OptionalIfParamValNoInArray("account",[ + 'admin' + ]), + new Integer() + ] + ); + $num->parsedValue($request); + + $account = new Param( + name: "account" + ); + $account->parsedValue($request); + + $allDefineParams = [ + 'account'=>$account, + 'num'=>$num, + ]; + + $ret = true; + $rules = $num->validate; + /** @var AbstractValidator $rule */ + foreach ($rules as $rule){ + $rule->allCheckParams($allDefineParams); + $ret = $rule->execute($num,$request); + if(!$ret){ + break; + } + } + + $this->assertEquals(true,$ret); + } + + + function testFail() + { + $request = new Request(); + $request->withQueryParams([ + "account"=>"admin", + ]); + + $num = new Param( + name:"num", + validate: [ + new OptionalIfParamValNoInArray("account",[ + 'admin' + ]), + new Integer() + ] + ); + $num->parsedValue($request); + + $account = new Param( + name: "account" + ); + $account->parsedValue($request); + + $allDefineParams = [ + 'account'=>$account, + 'num'=>$num, + ]; + + $ret = true; + $rules = $num->validate; + /** @var AbstractValidator $rule */ + foreach ($rules as $rule){ + $rule->allCheckParams($allDefineParams); + $ret = $rule->execute($num,$request); + if(!$ret){ + break; + } + } + + $this->assertEquals(false,$ret); + } + + + function testSuccess() + { + $request = new Request(); + $request->withQueryParams([ + "account"=>"admin", + "num"=>1 + ]); + + $num = new Param( + name:"num", + validate: [ + new OptionalIfParamValNoInArray("account",[ + 'admin' + ]), + new Integer() + ] + ); + $num->parsedValue($request); + + $account = new Param( + name: "account" + ); + $account->parsedValue($request); + + $allDefineParams = [ + 'account'=>$account, + 'num'=>$num, + ]; + + $ret = true; + $rules = $num->validate; + /** @var AbstractValidator $rule */ + foreach ($rules as $rule){ + $rule->allCheckParams($allDefineParams); + $ret = $rule->execute($num,$request); + if(!$ret){ + break; + } + } + + $this->assertEquals(true,$ret); + } + + +} \ No newline at end of file