Metadata-Version: 2.1
Name: pytest-aoc
Version: 0.1.dev12
Summary: Downloads puzzle inputs for Advent of Code and synthesizes PyTest fixtures
Home-page: https://github.com/j0057/pytest-aoc
Author: Joost Molenaar
Author-email: j.j.molenaar@gmail.com
License: UNKNOWN
Description: # pytest-aoc
        
        This pytest plugin downloads puzzle inputs for [Advent of Code][1] and
        synthesizes fixtures that you can use in your tests.
        
        ## Installing and configuring
        
        Installing is easy: `pip install pytest-aoc`. Next you will need to configure
        _two_ things: for which event (year) the plugin should download inputs, and a
        valid session cookie. These are normally valid for about a month or so.
        
        To set the year, put it in `setup.cfg`:
        
            [tool:pytest]
            aoc_year = 2018
        
        Then, put a valid session ID in a file named `.cookie` and also name this file
        in your `.gitignore`.
        
        With these two things in place, when running pytest, this plugin will download
        any missing inputs, and generate pytest fixtures that you can use in your test
        functions, see 'Using' and 'Fixtures', below.
        
        ## Using
        
        With this plugin properly configured, you can write tests like this:
        
            def test_01a(day01_numbers):
                assert sum(day01_numbers) == 123
        
        Here, the parameter `day01_numbers` is a fixture that contains the numbers on
        each line in the file `input/day01.txt`.
        
        ## Fixtures
        
        ### dayNN\_text
        
        The text in the input file, but stripped of any leading and trailing whitespace.
        
        ### dayNN\_raw
        
        The raw text in the input file.
        
        ### dayNN\_lines
        
        A list of lines.
        
        ### dayNN\_numbers
        
        A list of numbers.
        
        ### dayNN\_number
        
        A single number.
        
        ### dayNN\_grid
        
        A list of lists, representing a grid of textual values.
        
        ### dayNN\_number\_grid
        
        A list of lists, representing a grid of numbers.
        
        ## Command-line and configuration options
        
        You can pass the options from the command line or set them in setup.cfg. The
        command line takes precedence.
        
        ### --aoc-year / aoc\_year
        
        (Mandatory) The year for which to download puzzle inputs.
        
        ### --aoc-session-id / aoc\_session\_id
        
        (Optional) The session ID to use for requesting puzzle inputs.
        
        ### --aoc-session-file / aoc\_session\_file
        
        (Optional; default `.cookie`) The file from which to read the session ID.
        
        ### --aoc-input-dir / aoc\_input\_dir
        
        (Optional; default `input`) The directory in which inputs are stored. Will be
        created if it doesn't exist.
        
Platform: UNKNOWN
Classifier: Framework :: Pytest
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3.7
Description-Content-Type: text/markdown
