Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
NickSdot committed Sep 21, 2021
1 parent 195529f commit 50d22c0
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 1 deletion.
6 changes: 5 additions & 1 deletion src/Illuminate/Validation/Validator.php
Original file line number Diff line number Diff line change
Expand Up @@ -1127,7 +1127,11 @@ public function sometimes($attribute, $rules, callable $callback)

foreach ($response->rules as $ruleKey => $ruleValue) {
if ($callback($payload, $this->dataForSometimesIteration($ruleKey, ! Str::endsWith($key, '.*')))) {
$this->addRules([$ruleKey => $ruleValue]);
if(is_array($rules)) {
$this->addRules([$key => $ruleValue]);
} else {
$this->addRules([$ruleKey => $ruleValue]);
}
}
}
}
Expand Down
46 changes: 46 additions & 0 deletions tests/Validation/ValidationValidatorTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -4378,6 +4378,52 @@ public function testItemAwareSometimesAddingRules()
$this->assertEquals(['attendee.name' => ['string', 'required'], 'attendee.title' => ['string', 'required'], 'attendee.type' => ['string', 'required']], $v->getRules());
}

public function testValidateSometimesImplicitEachWithAsterisksBeforeAndAfter()
{
$trans = $this->getIlluminateArrayTranslator();

$v = new Validator($trans, [
'foo' => [
['start' => '2016-04-19', 'end' => '2017-04-19'],
],
], []);
$v->sometimes('foo.*.start', ['before:foo.*.end'], function () {
return true;
});
$this->assertTrue($v->passes());

$v = new Validator($trans, [
'foo' => [
['start' => '2016-04-19', 'end' => '2017-04-19'],
],
], []);
$v->sometimes('foo.*.end', ['before:foo.*.start'], function () {
return true;
});

$this->assertTrue($v->fails());

$v = new Validator($trans, [
'foo' => [
['start' => '2016-04-19', 'end' => '2017-04-19'],
],
], []);
$v->sometimes('foo.*.end', ['after:foo.*.start'], function () {
return true;
});
$this->assertTrue($v->passes());

$v = new Validator($trans, [
'foo' => [
['start' => '2016-04-19', 'end' => '2017-04-19'],
],
], []);
$v->sometimes('foo.*.start', ['after:foo.*.end'], function () {
return true;
});
$this->assertTrue($v->fails());
}

public function testCustomValidators()
{
$trans = $this->getIlluminateArrayTranslator();
Expand Down

0 comments on commit 50d22c0

Please sign in to comment.