-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
Fix --complete flag in orm:ensure-production-settings command #8426
Conversation
@@ -62,7 +62,7 @@ protected function execute(InputInterface $input, OutputInterface $output) | |||
try { | |||
$em->getConfiguration()->ensureProductionSettings(); | |||
|
|||
if ($input->getOption('complete') !== null) { | |||
if (!$input->getOption('complete')) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
current symfony returns false
not sure if null
was returned in older version so I did switch to using !
instead for checking for false or null.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is a default value that can be set in addOption
. Without an explicit value it is null
.
https://github.com/symfony/console/blob/5.x/Command/Command.php#L400
It seems to be the same in 4.0 and 3.0.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Seems like its not possible to set a default value for InputOption::VALUE_NONE: https://github.com/symfony/console/blob/356c70659d6b48595f9f275cd7c4de0d5544c49c/Input/InputOption.php#L168
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So I could go with:
$input->getOption('complete') === true
$input->getOption('complete') !== false
or the current version.
The value of the input is set here to true
:
https://github.com/symfony/console/blob/356c70659d6b48595f9f275cd7c4de0d5544c49c/Input/ArgvInput.php#L248
And default value to false
:
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If it's a boolean then your current syntax should fit. You currently let it step into the if-block when the value is false
. It also looks like there are no tests yet that covers this class. Can you please create one that covers your changes?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@SenseException created the missing test class hope it matches how tests are created in this repository.
eff92c6
to
c6f5320
Compare
c6f5320
to
0025331
Compare
@doctrine/team-orm Do we need |
I don't think so. |
Change to the DoctrineTestCase |
Anything I can do to get this merged? |
Currently not. This will be handled by another reviewer after a second pair of eyes take a look at this PR. |
$input->getOption('complete') returns
false
and notnull
if not set.