once() ->andReturn(true); $request = new SettingStoreRequest; $this->assertTrue($request->authorize()); } #[Test] #[DataProvider('provideValidData')] public function test_valid_data(array $data) : void { $request = new SettingStoreRequest; $validator = Validator::make($data, $request->rules()); $this->assertFalse($validator->fails()); } /** * Provide Valid data for validation test */ public static function provideValidData() : array { return [ [[ 'key' => 'MyKey', 'value' => true, ]], [[ 'key' => 'MyKey', 'value' => 'MyValue', ]], [[ 'key' => 'MyKey', 'value' => 10, ]], ]; } #[Test] #[DataProvider('provideInvalidData')] public function test_invalid_data(array $data) : void { Settings::set(self::UNIQUE_KEY, 'uniqueValue'); $request = new SettingStoreRequest; $validator = Validator::make($data, $request->rules()); $this->assertTrue($validator->fails()); } /** * Provide invalid data for validation test */ public static function provideInvalidData() : array { return [ [[ 'key' => null, // required 'value' => '', ]], [[ 'key' => 'my-key', // alpha 'value' => 'MyValue', ]], [[ 'key' => 10, // alpha 'value' => 'MyValue', ]], [[ 'key' => 'mmmmmmoooooorrrrrreeeeeeettttttthhhhhhaaaaaaannnnnn128cccccchhhhhaaaaaarrrrrraaaaaaaccccccttttttttteeeeeeeeerrrrrrrrsssssss', // max:128 'value' => 'MyValue', ]], [[ 'key' => self::UNIQUE_KEY, // unique 'value' => 'MyValue', ]], ]; } }