Skip to content
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

Resolve linting issues, consolidate linting makefile targets #4432

Merged
merged 7 commits into from
May 16, 2019

Conversation

redshiftzero
Copy link
Contributor

@redshiftzero redshiftzero commented May 11, 2019

Status

Ready for review

Description of Changes

Changes proposed in this pull request:

Testing

  • Rebuild your virtualenv, run make lint locally, ensure all passes
  • CI lint job passes

Deployment

CI/dev only

Checklist

If you made changes to the server application code:

  • Linting (make lint) and tests (make -C securedrop test) pass in the development container

If you made non-trivial code changes:

  • I have written a test plan and validated it for this PR

@redshiftzero redshiftzero force-pushed the resolve-linting-issues branch 2 times, most recently from 7a501ee to bfde353 Compare May 11, 2019 18:53
@zenmonkeykstop
Copy link
Contributor

  • make lint passes locally
  • CI lint passes too, but staging-test-with-rebase does not, as enchant isn't available on the GCE Xenial instance

@heartsucker
Copy link
Contributor

This does not pass locally. Is this meant to be run in the dev container?

find . -name '*.py' | xargs pylint --reports=no --errors-only \
   --disable=no-name-in-module \
   --disable=unexpected-keyword-arg \
   --disable=too-many-function-args \
   --disable=import-error \
   --disable=no-member \
   --max-line-length=100
Using config file /home/heartsucker/code/freedomofpress/securedrop/securedrop/pylintrc
Traceback (most recent call last):
  File "/usr/local/bin/pylint", line 11, in <module>
    sys.exit(run_pylint())
  File "/usr/local/lib/python3.5/dist-packages/pylint/__init__.py", line 16, in run_pylint
    Run(sys.argv[1:])
  File "/usr/local/lib/python3.5/dist-packages/pylint/lint.py", line 1315, in __init__
    linter.load_config_file()
  File "/usr/local/lib/python3.5/dist-packages/pylint/config.py", line 678, in load_config_file
    self.global_set_option(option, value)
  File "/usr/local/lib/python3.5/dist-packages/pylint/config.py", line 576, in global_set_option
    self._all_options[opt].set_option(opt, value)
  File "/usr/local/lib/python3.5/dist-packages/pylint/config.py", line 768, in set_option
    value = _validate(value, optdict, optname)
  File "/usr/local/lib/python3.5/dist-packages/pylint/config.py", line 233, in _validate
    return _call_validator(_type, optdict, name, value)
  File "/usr/local/lib/python3.5/dist-packages/pylint/config.py", line 214, in _call_validator
    return VALIDATORS[opttype](optdict, option, value)
  File "/usr/local/lib/python3.5/dist-packages/pylint/config.py", line 204, in <lambda>
    'choice': lambda opt, name, value: _choice_validator(opt['choices'], name, value),
  File "/usr/local/lib/python3.5/dist-packages/pylint/config.py", line 161, in _choice_validator
    raise optparse.OptionValueError(msg % (name, value, choices))
optparse.OptionValueError: option spelling-dict: invalid value: 'en_US', should be in ['']
Makefile:7: recipe for target 'lint' failed

@rmol
Copy link
Contributor

rmol commented May 13, 2019

@heartsucker I think you just need to rebuild your virtualenv. It's missing pyenchant. I also ran into an error during molecule verify -s ansible-config before I ran make clean and bootstrapped it again. Now make lint works for me.

@conorsch
Copy link
Contributor

Rebuild your virtualenv

To accomplish this, I ran pip install -r securedrop/requirements/develop-requirements.txt. Target is now passing locally for me.

As for the CI failure, let's consider baking the enchant apt package into the CI base image, to keep CI runs snappy.

@conorsch
Copy link
Contributor

Built a new CI image (version-controlled outside of this repository), and pushed a small commit to retrigger a build. Let's monitor CI and see how it fares.

@conorsch
Copy link
Contributor

CI failed at

    RUNNING HANDLER [common : Wait for server to come back.] ***********************
    fatal: [app-staging -> localhost]: FAILED! => {"changed": false, "elapsed": 301, "msg": "Timeout when waiting for search string OpenSSH in 192.168.121.100:22"}
    fatal: [mon-staging -> localhost]: FAILED! => {"changed": false, "elapsed": 301, "msg": "Timeout when waiting for search string OpenSSH in 192.168.121.228:22"}

Rerunning to check if flake...

@conorsch
Copy link
Contributor

conorsch commented May 13, 2019

New CI box is reliably failing when staging VMs come back up after a reboot, as above. That's something we should look into fixing, but to unblock this PR, I'm going to delete the new box and add a task to install enchant inside the CI box on PR run, as originally suggested.

@conorsch
Copy link
Contributor

Update: the naive approach in ae3938f isn't sufficient for the CI environment, specifically because the remote user lacks sudo rights (all SD dev env operations are run as a normal user during the CI job). We can work around that, specifically by using the gcloud tooling directly to run SSH connections, or even to pass in a startup script that will enable us to sideload dependencies. Happy to take a closer look tomorrow, when back at a keyboard.

tons of false positives, we can re-enable this later
the choice here is to:

1. install enchant in the staging machine
2. break up development dependencies into what is needed for linting
and what is needed for the provisioning of staging machines

selecting the former, as having too many requirements files has
caused major confusion in the past.
@conorsch conorsch force-pushed the resolve-linting-issues branch 2 times, most recently from 0b6e3fa to b1313b1 Compare May 16, 2019 02:39
Rebuilds the GCP CI box on Stretch, rather than Xenial. Doing so fixed a
recurring problem during the "make staging" run where the staging VMs
did not come back up, causing Ansible to timeout during wait, and the
entire build to fail.
@conorsch conorsch force-pushed the resolve-linting-issues branch from 06201c9 to 45b7139 Compare May 16, 2019 05:45
@codecov-io
Copy link

codecov-io commented May 16, 2019

Codecov Report

Merging #4432 into develop will not change coverage.
The diff coverage is n/a.

Impacted file tree graph

@@           Coverage Diff            @@
##           develop    #4432   +/-   ##
========================================
  Coverage    83.72%   83.72%           
========================================
  Files           44       44           
  Lines         2956     2956           
  Branches       321      321           
========================================
  Hits          2475     2475           
  Misses         404      404           
  Partials        77       77

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 4b1b1ab...45b7139. Read the comment docs.

Copy link
Contributor

@kushaldas kushaldas left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Finally all CI green and it looks good to me. Approved.

@kushaldas kushaldas merged commit 62191c8 into develop May 16, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

make lint target fails locally
7 participants