Skip to content

Commit

Permalink
update tests to reflect removal of validate related methods
Browse files Browse the repository at this point in the history
  • Loading branch information
tambait committed Nov 24, 2020
1 parent 5a7383a commit 66a1fd1
Showing 1 changed file with 0 additions and 124 deletions.
124 changes: 0 additions & 124 deletions tests/Admin/AdminTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -71,12 +71,8 @@
use Sonata\Exporter\Source\SourceIteratorInterface;
use Symfony\Bridge\PhpUnit\ExpectDeprecationTrait;
use Symfony\Component\Filesystem\Filesystem;
use Symfony\Component\Form\FormBuilder;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\Form\FormEvent;
use Symfony\Component\Form\FormEvents;
use Symfony\Component\Form\FormFactory;
use Symfony\Component\Form\FormInterface;
use Symfony\Component\Form\FormRegistry;
use Symfony\Component\Form\ResolvedFormTypeFactory;
use Symfony\Component\HttpFoundation\ParameterBag;
Expand All @@ -85,7 +81,6 @@
use Symfony\Component\Routing\RouterInterface;
use Symfony\Component\Security\Core\Exception\AccessDeniedException;
use Symfony\Component\Validator\Mapping\MemberMetadata;
use Symfony\Component\Validator\Mapping\PropertyMetadataInterface;
use Symfony\Component\Validator\Validator\ValidatorInterface;
use Symfony\Contracts\Translation\TranslatorInterface;

Expand Down Expand Up @@ -1465,125 +1460,6 @@ public function testGetNewInstanceForEmbededAdminWithParentValue(): void
$this->assertSame($post, $tag->getPost());
}

public function testFormAddPostSubmitEventForPreValidation(): void
{
$modelAdmin = new ModelAdmin('sonata.post.admin.model', \stdClass::class, 'Sonata\FooBundle\Controller\ModelAdminController');
$object = new \stdClass();

$labelTranslatorStrategy = $this->createMock(LabelTranslatorStrategyInterface::class);
$modelAdmin->setLabelTranslatorStrategy($labelTranslatorStrategy);

$validator = $this->createMock(ValidatorInterface::class);
$validator
->method('getMetadataFor')
->willReturn($this->createMock(MemberMetadata::class));
$modelAdmin->setValidator($validator);

$modelManager = $this->createMock(ModelManagerInterface::class);
$modelManager
->method('getNewFieldDescriptionInstance')
->willReturn(new FieldDescription('name'));
$modelAdmin->setModelManager($modelManager);

// a Admin class to test that preValidate is called
$testAdminPreValidate = $this->createMock(AbstractAdmin::class);
$testAdminPreValidate->expects($this->once())
->method('preValidate')
->with($this->identicalTo($object));

$event = $this->createMock(FormEvent::class);
$event
->method('getData')
->willReturn($object);

$formBuild = $this->createMock(FormBuilder::class);
$formBuild->expects($this->once())
->method('addEventListener')
->with(
$this->identicalTo(FormEvents::POST_SUBMIT),
$this->callback(static function ($callback) use ($testAdminPreValidate, $event): bool {
if (\is_callable($callback)) {
$closure = $callback->bindTo($testAdminPreValidate);
$closure($event);

return true;
}

return false;
}),
$this->greaterThan(0)
);

$form = $this->createMock(FormInterface::class);
$formBuild->expects($this->once())
->method('getForm')
->willReturn($form)
;

$formContractor = $this->createMock(FormContractorInterface::class);
$formContractor
->method('getDefaultOptions')
->willReturn([]);
$formContractor
->method('getFormBuilder')
->willReturn($formBuild);

$modelAdmin->setFormContractor($formContractor);
$modelAdmin->setSubject($object);
$modelAdmin->defineFormBuilder($formBuild);
$modelAdmin->getForm();
}

public function testCanAddInlineValidationOnlyForGenericMetadata(): void
{
$modelAdmin = new ModelAdmin('sonata.post.admin.model', \stdClass::class, 'Sonata\FooBundle\Controller\ModelAdminController');
$object = new \stdClass();

$labelTranslatorStrategy = $this->createStub(LabelTranslatorStrategyInterface::class);
$modelAdmin->setLabelTranslatorStrategy($labelTranslatorStrategy);

$validator = $this->createStub(ValidatorInterface::class);
$metadata = $this->createStub(PropertyMetadataInterface::class);
$validator
->method('getMetadataFor')
->willReturn($metadata);
$modelAdmin->setValidator($validator);

$modelManager = $this->createStub(ModelManagerInterface::class);
$modelManager
->method('getNewFieldDescriptionInstance')
->willReturn(new FieldDescription('name'));
$modelAdmin->setModelManager($modelManager);

$event = $this->createStub(FormEvent::class);
$event
->method('getData')
->willReturn($object);

$formBuild = $this->createStub(FormBuilder::class);

$formContractor = $this->createStub(FormContractorInterface::class);
$formContractor
->method('getDefaultOptions')
->willReturn([]);
$formContractor
->method('getFormBuilder')
->willReturn($formBuild);

$modelAdmin->setFormContractor($formContractor);
$modelAdmin->setSubject($object);

$this->expectException(\RuntimeException::class);
$this->expectExceptionMessage(
sprintf(
'Cannot add inline validator for stdClass because its metadata is an instance of %s instead of Symfony\Component\Validator\Mapping\GenericMetadata',
\get_class($metadata)
)
);

$modelAdmin->defineFormBuilder($formBuild);
}

public function testRemoveFieldFromFormGroup(): void
{
$formGroups = [
Expand Down

0 comments on commit 66a1fd1

Please sign in to comment.