-
Notifications
You must be signed in to change notification settings - Fork 3
Add translation generator tests #80
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from 9 commits
Commits
Show all changes
10 commits
Select commit
Hold shift + click to select a range
b61599f
test: add tests for translation file generation generator.
3ab39e9
chore: remove fixture export.
a7a7d02
Merge remote-tracking branch 'origin/49-add-tests-generator-tests' in…
pirs1337 edf5296
feat: add tests
pirs1337 872c78b
Merge remote-tracking branch 'origin/master' into 49-add-translator-g…
pirs1337 3ba3ec5
refactor: code
pirs1337 94c145a
refactor: code
pirs1337 6067363
refactor: code
pirs1337 216a37b
refactor: code
pirs1337 3252fcb
refactor: code
pirs1337 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -9,6 +9,6 @@ | |
|
|
||
| 'exceptions' => [ | ||
| 'not_found' => ':Entity does not exist', | ||
| ] | ||
| ], | ||
|
|
||
| ]; | ||
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -127,6 +127,6 @@ | |
|
|
||
| 'exceptions' => [ | ||
| 'not_found' => ':Entity does not exist', | ||
| ] | ||
| ], | ||
|
|
||
| ]; | ||
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,31 @@ | ||
| <?php | ||
|
|
||
| namespace RonasIT\Support\Tests\Support\Translation; | ||
|
|
||
| use RonasIT\Support\Tests\Support\FileSystemMock; | ||
| use RonasIT\Support\Tests\Support\GeneratorMockTrait; | ||
|
|
||
| trait TranslationMockTrait | ||
| { | ||
| use GeneratorMockTrait; | ||
|
|
||
| public function mockFilesystem(): void | ||
| { | ||
| $fileSystemMock = new FileSystemMock(); | ||
|
|
||
| $fileSystemMock->translations = []; | ||
|
|
||
| $fileSystemMock->setStructure(); | ||
| } | ||
|
|
||
| public function mockFilesystemForAppend(): void | ||
| { | ||
| $validation = file_get_contents(getcwd() . '/tests/Support/Translation/validation_without_exceptions.php'); | ||
|
|
||
| $fileSystemMock = new FileSystemMock(); | ||
|
|
||
| $fileSystemMock->translations = ['validation.php' => $validation]; | ||
|
|
||
| $fileSystemMock->setStructure(); | ||
| } | ||
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,3 @@ | ||
| <?php | ||
|
|
||
| return []; | ||
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,82 @@ | ||
| <?php | ||
|
|
||
| namespace RonasIT\Support\Tests; | ||
|
|
||
| use Illuminate\Support\Facades\Event; | ||
| use Illuminate\Support\Facades\Lang; | ||
| use RonasIT\Support\Events\SuccessCreateMessage; | ||
| use RonasIT\Support\Events\WarningEvent; | ||
| use RonasIT\Support\Generators\TranslationsGenerator; | ||
| use RonasIT\Support\Tests\Support\Translation\TranslationMockTrait; | ||
|
|
||
| class TranslationGeneratorTest extends TestCase | ||
| { | ||
| use TranslationMockTrait; | ||
|
|
||
| public function testCreate() | ||
| { | ||
| $translations = $this->getJsonFixture('validation.json'); | ||
|
|
||
| Lang::shouldReceive('get')->andReturn($translations); | ||
|
|
||
| $this->mockFilesystem(); | ||
|
|
||
| app(TranslationsGenerator::class) | ||
| ->setModel('Post') | ||
| ->generate(); | ||
|
|
||
| $this->assertGeneratedFileEquals('validation.php', 'resources/lang/en/validation.php'); | ||
|
|
||
| $this->assertEventPushed( | ||
| className: SuccessCreateMessage::class, | ||
| message: 'Created a new Translations dump on path: vfs://root/resources/lang/en/validation.php', | ||
| ); | ||
| } | ||
|
|
||
| public function testCreateStubNotExist() | ||
| { | ||
| config(['entity-generator.stubs.validation' => 'incorrect_stub']); | ||
|
|
||
| app(TranslationsGenerator::class) | ||
| ->setModel('Post') | ||
| ->generate(); | ||
|
|
||
| $this->assertFileDoesNotExist('resources/lang/en/validation.php'); | ||
|
|
||
| $this->assertEventPushed( | ||
| className: WarningEvent::class, | ||
| message: 'Generation of validation has been skipped cause the view incorrect_stub from the config entity-generator.stubs.validation is not exists. Please check that config has the correct view name value.', | ||
| ); | ||
| } | ||
|
|
||
| public function testAppendNotFoundException() | ||
| { | ||
| $this->mockFilesystemForAppend(); | ||
|
|
||
| app(TranslationsGenerator::class) | ||
| ->setModel('Post') | ||
| ->generate(); | ||
|
|
||
| $this->assertGeneratedFileEquals('validation_append_not_found_exception.php', 'resources/lang/en/validation.php'); | ||
|
|
||
| Event::assertNothingDispatched(); | ||
| } | ||
|
|
||
| public function testAppendNotFoundExceptionStubNotExist() | ||
| { | ||
| config(['entity-generator.stubs.translation_not_found' => 'incorrect_stub']); | ||
|
|
||
| $this->mockFilesystemForAppend(); | ||
|
|
||
| app(TranslationsGenerator::class) | ||
| ->setModel('Post') | ||
| ->generate(); | ||
|
|
||
| $this->assertFileDoesNotExist('validation.php', 'resources/lang/en/validation.php'); | ||
|
|
||
| $this->assertEventPushed( | ||
| className: WarningEvent::class, | ||
| message: 'Generation of translation not found has been skipped cause the view incorrect_stub from the config entity-generator.stubs.translation_not_found is not exists. Please check that config has the correct view name value.', | ||
| ); | ||
| } | ||
| } |
158 changes: 158 additions & 0 deletions
158
tests/fixtures/TranslationGeneratorTest/validation.json
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,158 @@ | ||
| { | ||
|
||
| "accepted": "The :attribute field must be accepted.", | ||
| "accepted_if": "The :attribute field must be accepted when :other is :value.", | ||
| "active_url": "The :attribute field must be a valid URL.", | ||
| "after": "The :attribute field must be a date after :date.", | ||
| "after_or_equal": "The :attribute field must be a date after or equal to :date.", | ||
| "alpha": "The :attribute field must only contain letters.", | ||
| "alpha_dash": "The :attribute field must only contain letters, numbers, dashes, and underscores.", | ||
| "alpha_num": "The :attribute field must only contain letters and numbers.", | ||
| "array": "The :attribute field must be an array.", | ||
| "ascii": "The :attribute field must only contain single-byte alphanumeric characters and symbols.", | ||
| "before": "The :attribute field must be a date before :date.", | ||
| "before_or_equal": "The :attribute field must be a date before or equal to :date.", | ||
| "between": { | ||
| "array": "The :attribute field must have between :min and :max items.", | ||
| "file": "The :attribute field must be between :min and :max kilobytes.", | ||
| "numeric": "The :attribute field must be between :min and :max.", | ||
| "string": "The :attribute field must be between :min and :max characters." | ||
| }, | ||
| "boolean": "The :attribute field must be true or false.", | ||
| "can": "The :attribute field contains an unauthorized value.", | ||
| "confirmed": "The :attribute field confirmation does not match.", | ||
| "contains": "The :attribute field is missing a required value.", | ||
| "current_password": "The password is incorrect.", | ||
| "date": "The :attribute field must be a valid date.", | ||
| "date_equals": "The :attribute field must be a date equal to :date.", | ||
| "date_format": "The :attribute field must match the format :format.", | ||
| "decimal": "The :attribute field must have :decimal decimal places.", | ||
| "declined": "The :attribute field must be declined.", | ||
| "declined_if": "The :attribute field must be declined when :other is :value.", | ||
| "different": "The :attribute field and :other must be different.", | ||
| "digits": "The :attribute field must be :digits digits.", | ||
| "digits_between": "The :attribute field must be between :min and :max digits.", | ||
| "dimensions": "The :attribute field has invalid image dimensions.", | ||
| "distinct": "The :attribute field has a duplicate value.", | ||
| "doesnt_end_with": "The :attribute field must not end with one of the following: :values.", | ||
| "doesnt_start_with": "The :attribute field must not start with one of the following: :values.", | ||
| "email": "The :attribute field must be a valid email address.", | ||
| "ends_with": "The :attribute field must end with one of the following: :values.", | ||
| "enum": "The selected :attribute is invalid.", | ||
| "exists": "The selected :attribute is invalid.", | ||
| "extensions": "The :attribute field must have one of the following extensions: :values.", | ||
| "file": "The :attribute field must be a file.", | ||
| "filled": "The :attribute field must have a value.", | ||
| "gt": { | ||
| "array": "The :attribute field must have more than :value items.", | ||
| "file": "The :attribute field must be greater than :value kilobytes.", | ||
| "numeric": "The :attribute field must be greater than :value.", | ||
| "string": "The :attribute field must be greater than :value characters." | ||
| }, | ||
| "gte": { | ||
| "array": "The :attribute field must have :value items or more.", | ||
| "file": "The :attribute field must be greater than or equal to :value kilobytes.", | ||
| "numeric": "The :attribute field must be greater than or equal to :value.", | ||
| "string": "The :attribute field must be greater than or equal to :value characters." | ||
| }, | ||
| "hex_color": "The :attribute field must be a valid hexadecimal color.", | ||
| "image": "The :attribute field must be an image.", | ||
| "in": "The selected :attribute is invalid.", | ||
| "in_array": "The :attribute field must exist in :other.", | ||
| "integer": "The :attribute field must be an integer.", | ||
| "ip": "The :attribute field must be a valid IP address.", | ||
| "ipv4": "The :attribute field must be a valid IPv4 address.", | ||
| "ipv6": "The :attribute field must be a valid IPv6 address.", | ||
| "json": "The :attribute field must be a valid JSON string.", | ||
| "list": "The :attribute field must be a list.", | ||
| "lowercase": "The :attribute field must be lowercase.", | ||
| "lt": { | ||
| "array": "The :attribute field must have less than :value items.", | ||
| "file": "The :attribute field must be less than :value kilobytes.", | ||
| "numeric": "The :attribute field must be less than :value.", | ||
| "string": "The :attribute field must be less than :value characters." | ||
| }, | ||
| "lte": { | ||
| "array": "The :attribute field must not have more than :value items.", | ||
| "file": "The :attribute field must be less than or equal to :value kilobytes.", | ||
| "numeric": "The :attribute field must be less than or equal to :value.", | ||
| "string": "The :attribute field must be less than or equal to :value characters." | ||
| }, | ||
| "mac_address": "The :attribute field must be a valid MAC address.", | ||
| "max": { | ||
| "array": "The :attribute field must not have more than :max items.", | ||
| "file": "The :attribute field must not be greater than :max kilobytes.", | ||
| "numeric": "The :attribute field must not be greater than :max.", | ||
| "string": "The :attribute field must not be greater than :max characters." | ||
| }, | ||
| "max_digits": "The :attribute field must not have more than :max digits.", | ||
| "mimes": "The :attribute field must be a file of type: :values.", | ||
| "mimetypes": "The :attribute field must be a file of type: :values.", | ||
| "min": { | ||
| "array": "The :attribute field must have at least :min items.", | ||
| "file": "The :attribute field must be at least :min kilobytes.", | ||
| "numeric": "The :attribute field must be at least :min.", | ||
| "string": "The :attribute field must be at least :min characters." | ||
| }, | ||
| "min_digits": "The :attribute field must have at least :min digits.", | ||
| "missing": "The :attribute field must be missing.", | ||
| "missing_if": "The :attribute field must be missing when :other is :value.", | ||
| "missing_unless": "The :attribute field must be missing unless :other is :value.", | ||
| "missing_with": "The :attribute field must be missing when :values is present.", | ||
| "missing_with_all": "The :attribute field must be missing when :values are present.", | ||
| "multiple_of": "The :attribute field must be a multiple of :value.", | ||
| "not_in": "The selected :attribute is invalid.", | ||
| "not_regex": "The :attribute field format is invalid.", | ||
| "numeric": "The :attribute field must be a number.", | ||
| "password": { | ||
| "letters": "The :attribute field must contain at least one letter.", | ||
| "mixed": "The :attribute field must contain at least one uppercase and one lowercase letter.", | ||
| "numbers": "The :attribute field must contain at least one number.", | ||
| "symbols": "The :attribute field must contain at least one symbol.", | ||
| "uncompromised": "The given :attribute has appeared in a data leak. Please choose a different :attribute." | ||
| }, | ||
| "present": "The :attribute field must be present.", | ||
| "present_if": "The :attribute field must be present when :other is :value.", | ||
| "present_unless": "The :attribute field must be present unless :other is :value.", | ||
| "present_with": "The :attribute field must be present when :values is present.", | ||
| "present_with_all": "The :attribute field must be present when :values are present.", | ||
| "prohibited": "The :attribute field is prohibited.", | ||
| "prohibited_if": "The :attribute field is prohibited when :other is :value.", | ||
| "prohibited_unless": "The :attribute field is prohibited unless :other is in :values.", | ||
| "prohibits": "The :attribute field prohibits :other from being present.", | ||
| "regex": "The :attribute field format is invalid.", | ||
| "required": "The :attribute field is required.", | ||
| "required_array_keys": "The :attribute field must contain entries for: :values.", | ||
| "required_if": "The :attribute field is required when :other is :value.", | ||
| "required_if_accepted": "The :attribute field is required when :other is accepted.", | ||
| "required_if_declined": "The :attribute field is required when :other is declined.", | ||
| "required_unless": "The :attribute field is required unless :other is in :values.", | ||
| "required_with": "The :attribute field is required when :values is present.", | ||
| "required_with_all": "The :attribute field is required when :values are present.", | ||
| "required_without": "The :attribute field is required when :values is not present.", | ||
| "required_without_all": "The :attribute field is required when none of :values are present.", | ||
| "same": "The :attribute field must match :other.", | ||
| "size": { | ||
| "array": "The :attribute field must contain :size items.", | ||
| "file": "The :attribute field must be :size kilobytes.", | ||
| "numeric": "The :attribute field must be :size.", | ||
| "string": "The :attribute field must be :size characters." | ||
| }, | ||
| "starts_with": "The :attribute field must start with one of the following: :values.", | ||
| "string": "The :attribute field must be a string.", | ||
| "timezone": "The :attribute field must be a valid timezone.", | ||
| "unique": "The :attribute has already been taken.", | ||
| "uploaded": "The :attribute failed to upload.", | ||
| "uppercase": "The :attribute field must be uppercase.", | ||
| "url": "The :attribute field must be a valid URL.", | ||
| "ulid": "The :attribute field must be a valid ULID.", | ||
| "uuid": "The :attribute field must be a valid UUID.", | ||
| "custom": { | ||
| "attribute-name": { | ||
| "rule-name": "custom-message" | ||
| } | ||
| }, | ||
| "attributes": {}, | ||
| "exceptions": { | ||
| "not_found": ":Entity does not exist" | ||
| } | ||
| } | ||
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.