Skip to content

Latest commit

 

History

History
114 lines (100 loc) · 6.03 KB

SETUP.md

File metadata and controls

114 lines (100 loc) · 6.03 KB

Setup Dev Environment

Requirements to run the application

Ensure that you have docker and docker-compose installed on your machine, as well as the rest of the Python stack.

  • GitBash
  • Python 3.6.7
  • PiP
    • Download get-pip.py
    • Navigate to the file in a terminal, run 'python get-pip.py'
    • Add pip's directory to the path system environment variable (usually "\Scripts")
    • Pip is used to build the backend so that snyk can anaylze it locally
  • Docker
  • Docker Compose

Requirements for development environment

We use VS Code, and specific linting setup when developing the application. This ensures consistency in our code style.

  • Visual Studio Code
    • Install
      • Download VS Code for Windows
      • Download location is default: C:\Users\cbrock\AppData\Local\Programs\Microsoft VS Code
      • Check “Create a desktop icon”
      • Click “Install”
    • Customize Tools and Languages - install language specific packages
      • Python by Microsoft
      • Docker by Microsoft
      • Django by Baptiste Darthenay
      • PostgreSQL by Chris Kolkman
      • React Redux ES6 Snippets by Timothy McLane
      • ESLint by Dirk Baeumer
      • Prettier - Code formatter by Esben Petersen
      • Git History Diff by Hui Zhou
    • Linting Configuration
      • Pylint:
        1. Open '.\project-thundercat.vscode\settings.json' file
        2. Add the following settings:
          • "python.pythonPath": "C:\Users\<your_user>\AppData\Local\Programs\Python\Python36\python.exe"
          • _"python.testing.unittestArgs": ["-v", "-s", "./backend", "-p", "*test.py"]
          • "editor.tabCompletion": "on"
          • "python.formatting.provider": "black"
        3. Open the other settings.json file using the following path: C:\Users<your_user>\AppData\Roaming\Code\User\settings.json
        4. Add the following settings:
          • "explorer.confirmDragAndDrop": false
          • "eslint.enable": true
          • "editor.formatOnSave": true
          • "eslint.options": {"configFile": C:\_DEV\IdeaProjects\thundercat\project-thundercat\frontend\.eslintrc.json"}
          • "javascript.updateImportsOnFileMove.enabled": "always"
          • "window.zoomLevel": 0
          • "editor.accessibilitySupport": "off"
          • "python.linting.pylintEnabled": true
        5. Open a python file, hit save and there should be a popup saying that Linter pylint is not installed. Hit Install.
        6. Now, you can edit the desired settings from .pylintrc file (to disable messages, see line 54 of the config file)
        7. Click here for more details on most of the Pylint errors/warnings
      • ESLint:
        1. Open '.\project-thundercat.vscode\settings.json' file
        2. Add the following setting:
          • "eslint.enable": true
          • "editor.formatOnSave": true
          • "eslint.options": {"configFile": "<path_of_your_project_root>\\frontend\\.eslintrc.json"}
        3. ESLint is now installed and configured
          • If ESLint is not working, do the following steps:
            1. Close Docker: Right Click on Docker icon + Quit Docker
            2. Navigate in your Windows explorer and delete the folder called 'node_modules' under '.\\project-thundercat\\frontend'
            3. Start Docker
            4. Open a powershell window and do a 'docker-compose up'
            5. Wait a couple minutes to make sure that all packages have been downloaded
            6. Restart VS Code
        4. You can also add/edit/remove rules from .prettierrc.json file
        5. Click here for more details about ESLint or here to know more about the Airbnb React style
    • Other Useful Configurations
      • Add the following settings to your settings.json file:
        • "explorer.confirmDragAndDrop": false,
        • "javascript.updateImportsOnFileMove.enabled": "always",

Local automated validation

Learn more about these tools in REPORTING.md

Snyk

Snyk is a security scanning tool that helps ensure the security of open source packages.

  • Run 'npm install -g snyk' in a terminal
  • Run 'npm install -g snyk-to-html' in a terminal
    • This allows for clean output to html files when snyk is run locally
    • Locally detected vulnerabilities can be documented in the repo and version controlled
  • See snyk.md for an explanation of why snyk is installed locally rather than in the containers
  • Add the npm directory containing snyk to the path system environment variable (usually "C:\Users<name>\AppData\Roaming\npm")
    • Note: You may need to restart your computer for this change to take effect
  • Create an account on snyk.io
  • Run 'snyk auth' in a terminal
  • Login when prompted (either in using the provided URL or in the opened browser)

Accessibility Check Tool (pa11y)

Accessibility requirements cannot be ensured entirely through automated checks, but they do help ensure we are meeting basic standards. Pa11y is a tool that helps us do this.

  • Run 'run 'npm install -g pa11y' in a terminal
  • Run also 'npm install -g pa11y pa11y-reporter-html' in a terminal
    • This allows for clean output to html file when this tool is run locally
    • It detects errors, warnings and notices related to accessibility of the application
  • Make sure that the npm directory containing pa11y is part of the path system environment variable (usually "C:\Users<name>\AppData\Roaming\npm")
    • Should have already been added during Snyk configuration (see above)
  • Click here to have more details about pa11y.