Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Add poetry and fix problem from #23 #25

Merged
merged 44 commits into from
Jun 15, 2022
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
c9c3efa
Add poetry, all configs and dependences now are in pyproject.toml, pc…
Jun 5, 2022
cc394fb
Fix: Dependencies versions
Jun 5, 2022
3dabd25
Feature: Scratch files to document the project
Jun 5, 2022
697ade8
Feature: Improve CI/CD with poetry and removing pyright workaround
Jun 5, 2022
1a2c94f
Fix: Add black and isort in dependencies
Jun 5, 2022
7176fd0
Feature: Add a script to run all tests, just type "poetry run all_test"
Jun 5, 2022
13b1b19
Feature: Add something in documentations
Jun 6, 2022
ea7e6c4
Merge branch 'main' into feature/poetry
Jun 8, 2022
2de548e
Fix: Project version, Author, Python versions, Pandas version
Jun 8, 2022
8bcb394
Fix: Remove old test file documentation
Jun 8, 2022
cf96463
Fix: Remove old pyright configs
Jun 8, 2022
ec78fab
Fix: Documentation in README.md with links
Jun 8, 2022
9f44c9b
Fix: pyproject.toml python compatibility
Jun 8, 2022
34ec92a
Fix: Add tests with wheel
Jun 8, 2022
728e449
Fix: Remove pytests from tests against dist
Jun 8, 2022
7871b94
Fix: Remove Source code distribution on tests after install wheel
Jun 8, 2022
e5040a4
Fix: Using shutil to remove dir
Jun 8, 2022
9259b96
Fix: Improve local tests and fix CI tests
Jun 8, 2022
8d05d17
Fix: Add metadata to pyproject.toml when build a wheel
Jun 8, 2022
34c8305
Fix: Replace default "poetry.scripts" equivalent to console_scripts f…
Jun 8, 2022
b9677bd
Fix: Improving docs with instructions to update dependencies "poetry …
Jun 9, 2022
13d738d
Fix: Split Dev from Dist Dependencies
Jun 10, 2022
b646c9a
Refactor: Util test scripts
Jun 10, 2022
0e3ea0a
CI: All tests call poe to run
Jun 10, 2022
fbff5dc
Docs: Improving setup and test documentation
Jun 10, 2022
ce3a4f5
Refactor: Improving test_src (I still think it could be better)
Jun 10, 2022
b398255
Docs: Improving poe tests documentation
Jun 10, 2022
40836f2
Style: Apply black and isort to new scripts code
Jun 10, 2022
3cf7947
Fix: Bug when test_src code fails, test_dist continues to test
Jun 10, 2022
38a64d6
Fix: Error in test documentation
Jun 10, 2022
54a846a
Docs: Improving CLI help documentation to run tests
Jun 10, 2022
36fc564
Docs: Improving CLI help documentation to run tests
Jun 10, 2022
0f73192
CI: Runs CI only when change code or dependencies
Jun 10, 2022
1d73e23
Docs: Fix Mc Donald's english errors
Jun 10, 2022
fe21dd2
Fix: Package test
Jun 12, 2022
bc550a6
Fix: Package Test
Jun 12, 2022
d4467e0
CI: Fix package test
Jun 12, 2022
0f4eb0b
Fix: add project to sys path
Jun 12, 2022
5a17251
Refactor: Folder Hierarquie, Rollback job, refresh setup docs
Jun 14, 2022
5667178
Fix: Add rollback to test_dist
Jun 14, 2022
4c6d838
Feature: Add code style check
Jun 14, 2022
ba94941
Refactor: Improving rollback
Jun 14, 2022
3abae80
Feature: add clean cache option in local tests
Jun 14, 2022
0aaeadb
Fix: code style check
Jun 14, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
80 changes: 29 additions & 51 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,59 +2,37 @@ name: 'Test'

on: [push, pull_request, workflow_dispatch]


jobs:
test:
runs-on: ubuntu-18.04
runs-on: ${{ matrix.os }}
timeout-minutes: 10
strategy:
matrix:
os: [ubuntu-latest, windows-latest, macos-latest]
python-version: ['3.8', '3.9', '3.10']

steps:
- name: Check out code
uses: actions/checkout@v2

- name: Setup Python
uses: actions/setup-python@v2
with:
python-version: "3.9"

- name: Cache pip
uses: actions/cache@v2
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }}
restore-keys: |
${{ runner.os }}-pip-

- name: Install dependencies
run:
python -m pip install -r tests/requirements.txt

- name: Run pyright tests
uses: gramster/pyright-action@main
with:
project: pyrighttestconfig.json
warn-partial: true

- name: Run pytest
run:
pytest tests/pandas

- name: Run mypy
run:
mypy tests/pandas typings/pandas

- name: Build wheel and install and remove typings
run: |
python setup.py build bdist_wheel
find ./dist/*.whl | xargs pip install
rm -rf typings
pip install pyright

- name: Run pyright against dist
uses: gramster/pyright-action@main
with:
project: pyrightdistconfig.json
warn-partial: true

- name: Run mypy against dist
run:
mypy tests/pandas
breno-jesus-fernandes marked this conversation as resolved.
Show resolved Hide resolved

- uses: actions/checkout@v2

- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v2
with:
python-version: ${{ matrix.python-version }}

- name: Upgrade pip
run: |
python -m pip install --upgrade pip
- name: Install Poetry and project dependencies
run: |
pip install poetry
poetry install
- name: Run Pyright
run: poetry run pyright

- name: Run Pytest
run: poetry run pytest

- name: Run MyPy
run: poetry run mypy pandas-stubs tests
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -127,3 +127,4 @@ dmypy.json

# Pyre type checker
.pyre/
/poetry.lock
8 changes: 6 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,13 @@ This is the home for pandas typing stubs supported by the pandas core team. The

To contribute changes to the stubs, you must include an appropriate test. See `pandas-stubs/tests` for examples.

## Build instructions
## Documentation

Use `python setup.py build bdist_wheel` to build the wheel. NOTE: `setuptools 62.3.2` is required!
- [How to setup the enviroment](docs/1%20-%20setup.md)
- [How to test the project](docs/2%20-%20tests.md)
- [How to follow the code style](docs/3%20-%20style.md)
- [Security stuffs](docs/4%20-%20security.md)
- [How to publish](docs/5%20-%20publish.md)

## Evolution

Expand Down
7 changes: 7 additions & 0 deletions docs/1 - setup.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
## Setup Environment

- Make sure you have python >= 3.8 installed
- Install poetry if you still don't have: pip install poetry
- Install the project dependencies with: poetry install -vvv
- Run all tests to make sure the project is ok: poetry run all_tests

5 changes: 5 additions & 0 deletions docs/2 - tests.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
## Test

- These tests originally came from https://github.com/VirtusLab/pandas-stubs.


5 changes: 5 additions & 0 deletions docs/3 - style.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
## Code style

- It's important to follow the code style from the project:
- poetry run black pandas-stubs tests scripts
- poetry run isort pandas-stubs tests scripts
3 changes: 3 additions & 0 deletions docs/4 - security.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
## Security

-
3 changes: 3 additions & 0 deletions docs/5 - publish.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
## Publish

You know ... just type "poetry publish pandas-stubs"
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
37 changes: 36 additions & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,3 +1,32 @@
[tool.poetry]
name = "pandas-stubs"
version = "1.4.2.20220608"
description = "Stubs for pandas"
authors = ["The Pandas Development Team"]
packages = [
{ "include" = "pandas-stubs"}
]

[tool.poetry.dependencies]
python = ">=3.8,<3.11"

[tool.poetry.dev-dependencies]
pandas = "1.4.*"
mypy = ">=0.960"
typing-extensions = ">=4.2.0"
matplotlib = ">=3.3.2"
pytest = ">=7.1.2"
pyright = ">=1.1.251"
black = ">=22.3.0"
isort = ">=5.10.1"

[build-system]
requires = ["poetry-core>=1.0.0"]
build-backend = "poetry.core.masonry.api"

[tool.poetry.scripts]
all_tests = "scripts.tests:test_all"

[tool.black]
line_length = 88
target_version = ["py39"]
Expand Down Expand Up @@ -41,7 +70,7 @@ extra_standard_library = [

[tool.mypy]
# Import discovery
mypy_path = "typings"
mypy_path = "."
namespace_packages = false
explicit_package_bases = false
ignore_missing_imports = true
Expand Down Expand Up @@ -86,3 +115,9 @@ strict_equality = true
show_error_context = false
show_column_numbers = false
show_error_codes = true

[tool.pyright]
typeCheckingMode = "basic"
stubPath = "."
include = ["tests", "pandas-stubs"]
useLibraryCodeForTypes = true
4 changes: 0 additions & 4 deletions pyrightdistconfig.json

This file was deleted.

8 changes: 0 additions & 8 deletions pyrighttestconfig.json

This file was deleted.

5 changes: 0 additions & 5 deletions runtests.bat

This file was deleted.

5 changes: 0 additions & 5 deletions runtests.sh

This file was deleted.

File renamed without changes.
13 changes: 13 additions & 0 deletions scripts/tests.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
import subprocess


def test_all():

cmd = ['mypy', 'pandas-stubs', 'tests']
subprocess.run(cmd)

cmd = ['pytest']
subprocess.run(cmd)

cmd = ['pyright']
subprocess.run(cmd)
43 changes: 0 additions & 43 deletions setup.cfg

This file was deleted.

45 changes: 0 additions & 45 deletions setup.py

This file was deleted.

3 changes: 0 additions & 3 deletions tests/pandas/README.md

This file was deleted.

10 changes: 0 additions & 10 deletions tests/requirements.txt

This file was deleted.

9 changes: 0 additions & 9 deletions tests/run_tests.sh

This file was deleted.

File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.