once() ->andReturn(true); $request = new TwoFAccountBatchRequest(); $this->assertTrue($request->authorize()); } #[Test] #[DataProvider('provideValidData')] public function test_valid_data(array $data) : void { $request = new TwoFAccountBatchRequest(); $validator = Validator::make($data, $request->rules()); $this->assertFalse($validator->fails()); } /** * Provide Valid data for validation test */ public static function provideValidData() : array { return [ [[ 'ids' => '1', ]], [[ 'ids' => '1,2,5', ]], ]; } #[Test] #[DataProvider('provideInvalidData')] public function test_invalid_data(array $data) : void { $request = new TwoFAccountBatchRequest(); $validator = Validator::make($data, $request->rules()); $this->assertTrue($validator->fails()); } /** * Provide invalid data for validation test */ public static function provideInvalidData() : array { return [ [[ 'ids' => '', // required ]], [[ 'ids' => null, // required ]], [[ 'ids' => true, // string ]], [[ 'ids' => 10, // string ]], [[ 'ids' => 'notaCommaSeparatedList', // regex ]], [[ 'ids' => 'a,b', // regex ]], [[ 'ids' => 'a,1', // regex ]], [[ 'ids' => ',1,2', // regex ]], [[ 'ids' => '1,,2', // regex ]], [[ 'ids' => '1,2,', // regex ]], [[ 'ids' => ',1,2,', // regex ]], [[ 'ids' => '1;2', // regex ]], ]; } }