Skip to main content

Converts Terraform 0.12+ variables file into a Markdown table

Project description

tfvars2markdown

Converts Terraform 0.12+ variables file into a Markdown table

Why tfvars2markdown

Friends don't let friends provide Terraform modules without READMEs containing input variables and outputs.

This Python package can generate Markdown-flavored tables for input variables for you by reading .tf files in a folder.

Generated Markdown table is compatible with the following services:

  • Github
  • Bitbucket
  • GitLab

Install

pip install tfvars2markdown

Usage

tfvars2markdown my_vars.tf

Options

Argument Description Default value Required
tf_vars_file Path to the .tf file containing variables - True
-t/--no-ticks Disable backticks around values in "Type" and "Default" columns False False
-d/--heading Changes the default "Inputs" heading. Only first level heading (#) is supported. Inputs False

Examples

Defaults

$ tfvars2markdown vars.tf
# Inputs
|    Name    |                                      Description                                      |      Type      |         Default         | Required |
|------------|---------------------------------------------------------------------------------------|:--------------:|:-----------------------:|:--------:|
| some_var_1 | Some description var_1                                                                |    `string`    |          `foo`          |   yes    |
| some_var_2 | Some description var_2                                                                |     `bool`     |         `False`         |   yes    |
| some_var_3 | Some description var_3                                                                |    `number`    |          `12`           |   yes    |
| some_var_4 | -                                                                                     | `list(string)` | `['foo', 'bar', 'baz']` |   yes    |
| some_var_5 | Some description var_5. This is a very long description with unicode characters ćšđž |  `list(bool)`  |  `[True, True, False]`  |   yes    |
| some_var_6 | Some description var_6                                                                | `list(number)` |       `[1, 2, 3]`       |   yes    |
| some_var_7 | Some description var_7. No defaults provided                                          |     `any`      |            -            |   yes    |
| some_var_8 | Some description var_8. No type or default provided                                   |       -        |            -            |   yes    |
| some_var_9 | Some description var_8. No type or default provided                                   |       -        |            -            |   yes    |

No backticks

$ tfvars2markdown --no-ticks vars.tf
# Inputs
|    Name    |                                      Description                                      |     Type     |        Default        | Required |
|------------|---------------------------------------------------------------------------------------|:------------:|:---------------------:|:--------:|
| some_var_1 | Some description var_1                                                                |    string    |          foo          |   yes    |
| some_var_2 | Some description var_2                                                                |     bool     |         False         |   yes    |

Different heading

$ tfvars2markdown --heading "my input vars" vars.tf
# my input vars
|    Name    |                                      Description                                      |      Type      |         Default         | Required |
|------------|---------------------------------------------------------------------------------------|:--------------:|:-----------------------:|:--------:|
| some_var_1 | Some description var_1                                                                |    `string`    |          `foo`          |   yes    |
| some_var_2 | Some description var_2                                                                |     `bool`     |         `False`         |   yes    |

Due to limitations in pytablewriter only first level heading (#) is supported.

Tests

Install test_requirements.txt and run

python -m unittest discover

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tfvars2markdown-0.0.4.tar.gz (4.2 kB view details)

Uploaded Source

Built Distribution

tfvars2markdown-0.0.4-py3-none-any.whl (5.1 kB view details)

Uploaded Python 3

File details

Details for the file tfvars2markdown-0.0.4.tar.gz.

File metadata

  • Download URL: tfvars2markdown-0.0.4.tar.gz
  • Upload date:
  • Size: 4.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.1

File hashes

Hashes for tfvars2markdown-0.0.4.tar.gz
Algorithm Hash digest
SHA256 80beb8a56b8030003ed509b68c917a7465b8a5f0bd9318f83c2a01799007fd98
MD5 ece720f44dd5908e078157d5137d0b91
BLAKE2b-256 0dc216efe42519d879e531f1f3bec06c91701faafe45bd159a8dc95e39cb87e9

See more details on using hashes here.

File details

Details for the file tfvars2markdown-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: tfvars2markdown-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 5.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.1

File hashes

Hashes for tfvars2markdown-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a79dfdf6ddf23f53492f1e8a994ec1650da4c0a2f022a59f334821d2bb51e569
MD5 0a2c70872613d15a9d41573d6e896f60
BLAKE2b-256 7e369dc38151000cf893cfa3d3e2404bb39201e2776b13d8839d3a1c2ee5162b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page