GitLab CI - PHPCS - NoSpaceBefore and NoSpaceAfter

Created on 24 March 2024, about 1 year ago
Updated 9 April 2024, 12 months ago

Problem/Motivation

PHPCS is reporting a total of 208 problems. Here is a summary of them:

--------------------------------------------------------------------------------
    SOURCE                                                                 COUNT
--------------------------------------------------------------------------------
[x] Squiz.WhiteSpace.OperatorSpacing.NoSpaceAfter                          28
[x] Squiz.WhiteSpace.OperatorSpacing.NoSpaceBefore                         28
[ ] Drupal.Files.LineLength.TooLong                                        22
[x] SlevomatCodingStandard.Namespaces.AlphabeticallySortedUses.Incorrectl  15
[x] SlevomatCodingStandard.ControlStructures.RequireNullCoalesceOperator.  11
[x] Squiz.WhiteSpace.SuperfluousWhitespace.EndLine                         9
[x] Generic.PHP.UpperCaseConstant.Found                                    8
[x] Drupal.WhiteSpace.Comma.NoSpace                                        7
[x] Drupal.Commenting.TodoComment.TodoFormat                               6
[ ] Drupal.Commenting.VariableComment.Missing                              6
[x] Drupal.ControlStructures.InlineControlStructure.NotAllowed             6
[x] Generic.Formatting.SpaceAfterCast.NoSpace                              6
[x] Drupal.Classes.UnusedUseStatement.UnusedUse                            5
[x] Drupal.ControlStructures.ControlSignature.SpaceAfterKeyword            4
[x] Drupal.Arrays.Array.ArrayIndentation                                   3
[x] Drupal.Commenting.FunctionComment.Missing                              3
[ ] Drupal.NamingConventions.ValidVariableName.LowerCamelName              3
[x] SlevomatCodingStandard.PHP.ShortList.LongListUsed                      3
[x] Squiz.Functions.FunctionDeclarationArgumentSpacing.SpaceAfterEquals    3
[x] Squiz.Functions.FunctionDeclarationArgumentSpacing.SpaceBeforeEquals   3
[x] Drupal.Arrays.Array.ArrayClosingIndentation                            2
[x] Drupal.Arrays.Array.CommaLastItem                                      2
[x] Drupal.Commenting.DataTypeNamespace.DataTypeNamespace                  2
[ ] Drupal.Commenting.FunctionComment.MissingReturnComment                 2
[x] SlevomatCodingStandard.TypeHints.DeclareStrictTypes.IncorrectStrictTy  2
[ ] Drupal.Arrays.Array.LongLineDeclaration                                1
[x] Drupal.Classes.ClassDeclaration.CloseBraceAfterBody                    1
[x] Drupal.Classes.UseGlobalClass.RedundantUseStatement                    1
[x] Drupal.Commenting.ClassComment.Missing                                 1
[x] Drupal.Commenting.ClassComment.SpacingAfter                            1
[x] Drupal.Commenting.DocComment.SpacingBeforeTags                         1
[ ] Drupal.Commenting.FunctionComment.MissingParamType                     1
[x] Drupal.Commenting.FunctionComment.WrongStyle                           1
[x] Drupal.Commenting.InlineComment.NotCapital                             1
[x] Drupal.Commenting.PostStatementComment.Found                           1
[x] Drupal.ControlStructures.ControlSignature.SpaceBeforeSemicolon         1
[ ] Drupal.NamingConventions.ValidFunctionName.InvalidPrefix               1
[ ] Drupal.Semantics.FunctionT.NotLiteralString                            1
[x] Drupal.WhiteSpace.OpenTagNewline.BlankLine                             1
[ ] Generic.CodeAnalysis.UselessOverridingMethod.Found                     1
[x] Generic.PHP.LowerCaseKeyword.Found                                     1
[x] Squiz.Functions.MultiLineFunctionDeclaration.OneParamPerLine           1
[x] Squiz.WhiteSpace.FunctionSpacing.AfterLast                             1
[x] Squiz.WhiteSpace.SuperfluousWhitespace.EmptyLines                      1
--------------------------------------------------------------------------------
A TOTAL OF 208 SNIFF VIOLATIONS WERE FOUND IN 44 SOURCES
--------------------------------------------------------------------------------
PHPCBF CAN FIX THE 35 MARKED SOURCES AUTOMATICALLY (170 VIOLATIONS IN TOTAL)
--------------------------------------------------------------------------------

Trying to fix all of them in one issue would be difficult to review, and would risk introducing unintended errors, so I suggest splitting the fixes into a number of issues.

For this issue just fixing the first two on the list would cut out a quarter of the problems.

Steps to reproduce

Open GitLab in browser and view latest pipeline: https://git.drupalcode.org/issue/smart_date-3433051/-/jobs/1140092

Proposed resolution

For this issue, I suggest foxusing on the first two types of error:

Squiz.WhiteSpace.OperatorSpacing.NoSpaceAfter
Squiz.WhiteSpace.OperatorSpacing.NoSpaceBefore

These relate to spaces before and after operators.

In ParseDates.php, there are a number of instances of 24*60*60, relating to the number of seconds in a day. I think it would be clearer to add a constant to the start of the class as follows:

const SECONDS_IN_DAY = 24 * 60 * 60;

Then replace all the hard coded values with the constant.

As PHP problems do not overlap JavaScript errors, these issues can be worked on in parallel with the ESLint fixes.

Remaining tasks

Related issue 📌 Add Gitlab CI Fixed needs to be merged first.

Insert spaces around operators where mandated.

Replace 24*60*60 with constant in ParseDates.php.

When all PHPCS errors have been resolved, the phpcs tests can be set to require passing.

User interface changes

N/A

API changes

N/A

Data model changes

N/A

📌 Task
Status

Fixed

Version

4.1

Component

Code

Created by

🇮🇪Ireland lostcarpark

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

Production build 0.71.5 2024