`ecoindex-cli` is a CLI tool that let you make ecoindex tests on given pages
Project description
Ecoindex-Cli
This tool provides an easy way to analyze websites with Ecoindex from your local computer using multi-threading. You have the ability to:
- Make the analysis on multiple pages
- Define multiple screen resolution
- Make a recursive analysis from a given website
This CLI is built on top of ecoindex-python with Typer
The output is always a CSV file with the results of the analysis.
Requirements
- Python ^3.10
- pip
Setup
pip install --user -U ecoindex-cli
Use case
The cli gets 2 commands: analyze
and report
which can be used separately:
ecoindex-cli --help
Usage: ecoindex-cli [OPTIONS] COMMAND [ARGS]...
Ecoindex cli to make analysis of webpages
Options:
--install-completion [bash|zsh|fish|powershell|pwsh]
Install completion for the specified shell.
--show-completion [bash|zsh|fish|powershell|pwsh]
Show completion for the specified shell, to
copy it or customize the installation.
--help Show this message and exit.
Commands:
analyze Make an ecoindex analysis of given webpages or website.
report If you already performed an ecoindex analysis and have your...
Make a simple analysis
You give just one web url
ecoindex-cli analyze --url http://www.ecoindex.fr
Result
There are 1 url(s), do you want to process? [Y/n]:
1 urls for 1 window size
Processing [####################################] 100%
🙌️ File /tmp/ecoindex-cli/output/www.ecoindex.fr/2021-04-20_164433/results.csv written !
This makes an analysis with a screen resolution of 1920x1080px by default and with the last known version of chromedriver. You can set those settings with options:
--window-size
and--chrome-version
Set the output file
You can define the csv output file
ecoindex-cli analyze --url http://www.ecoindex.fr --output-file ~/ecoindex-results/ecoindex.csv
Result
📁️ Urls recorded in file `input/www.ecoindex.fr.csv`
There are 1 url(s), do you want to process? [Y/n]:
1 urls for 1 window size with 2 maximum workers
Processing [####################################] 100%
🙌️ File /home/vvatelot/ecoindex-results/ecoindex.csv written !
Export to JSON file
By default, the results are exported to a CSV file. But, you can specify to export the results to a JSON file.
ecoindex-cli analyze --url http://www.ecoindex.fr --export-format json
Result
📁️ Urls recorded in file `input/www.ecoindex.fr.csv`
There are 1 url(s), do you want to process? [Y/n]:
1 urls for 1 window size with 2 maximum workers
Processing [####################################] 100%
🙌️ File /tmp/ecoindex-cli/output/www.ecoindex.fr/2022-03-05_215320/results.json written !
Multiple url analysis
ecoindex-cli analyze --url http://www.ecoindex.fr --url https://www.greenit.fr/
Result
There are 2 url(s), do you want to process? [Y/n]:
2 urls for 1 window size with 2 maximum workers
Processing [####################################] 100%
🙌️ File /tmp/ecoindex-cli/output/www.ecoindex.fr/2021-04-20_164524/results.csv written !
Provide urls from a file
You can use a file with given urls that you want to analyze: One url per line. This is helpful if you want to play the same scenario recurrently.
ecoindex-cli analyze --urls-file input/ecoindex.csv
Result
There are 2 url(s), do you want to process? [Y/n]:
2 urls for 1 window size with 2 maximum workers
Processing [####################################] 100%
🙌️ File /tmp/ecoindex-cli/output/www.ecoindex.fr/2021-04-20_164524/results.csv written !
Make a recursive analysis
You can make a recursive analysis of a given webiste. This means that the app will try to find out all the pages into your website and launch an analysis on all those web pages. ⚠️ This can process for a very long time! Use it at your own risks!
ecoindex-cli analyze --url http://www.ecoindex.fr --recursive
Result
⏲️ Crawling root url http://www.ecoindex.fr -> Wait a minute !
📁️ Urls recorded in file `/tmp/ecoindex-cli/input/www.ecoindex.fr.csv`
There are 3 url(s), do you want to process? [Y/n]:
3 urls for 1 window size with 2 maximum workers
Processing [####################################] 100%
🙌️ File /tmp/ecoindex-cli/output/www.ecoindex.fr/2021-04-20_164729/results.csv written !
Using multi-threadging
You can use multi-threading to speed up the analysis when you have a lot of websites to analyze. In this case, you can define the maximum number of workers to use:
ecoindex-cli analyze --url http://www.ecoindex.fr --url https://www.greenit.fr/ --max-workers 10
Result
There are 2 url(s), do you want to process? [Y/n]:
2 urls for 1 window size with 10 maximum workers
Processing [####################################] 100%
🙌️ File /tmp/ecoindex-cli/output/www.ecoindex.fr/2021-04-20_164524/results.csv written !
By default, the number of maximum workers is set to CPU count.
Disable console interaction
You can disable confirmations, and force the app to answer yes to all of them. It can be useful if you need to start the app from another script, or if you have no time to wait it to finish.
ecoindex-cli analyze --url http://www.ecoindex.fr --recursive --no-interaction
Result
⏲️ Crawling root url http://www.ecoindex.fr -> Wait a minute !
📁️ Urls recorded in file `/tmp/ecoindex-cli/input/www.ecoindex.fr.csv`
3 urls for 1 window size with 2 maximum workers
Processing [####################################] 100%
🙌️ File /tmp/ecoindex-cli/output/www.ecoindex.fr/2021-11-04_081913/results.csv written !
Set other screen resolutions
You can provide other screen resolutions. By default, the screen resolution is 1920x1080px
but you can provide other resolution for example if you want to test ecoindex for mobile.
ecoindex-cli analyze --url http://www.ecoindex.fr --window-size 1920,1080 --window-size 386,540
Result
There are 1 url(s), do you want to process? [Y/n]:
1 urls for 2 window size with 2 maximum workers
Processing [####################################] 100%
🙌️ File /tmp/ecoindex-cli/output/www.ecoindex.fr/2021-04-21_212244/results.csv written !
Generate a html report
You can generate a html report easily at the end of the analysis. You just have to add the option --html-report
.
ecoindex-cli analyze --url http://www.ecoindex.fr --recursive --html-report
Result
⏲️ Crawling root url http://www.ecoindex.fr -> Wait a minute !
📁️ Urls recorded in file `input/www.ecoindex.fr.csv`
There are 3 url(s), do you want to process? [Y/n]:
3 urls for 1 window size with 2 maximum workers
Processing [####################################] 100%
🙌️ File output/www.ecoindex.fr/2021-04-21_212127/results.csv written !
🦄️ Amazing! A report has been generated to /tmp/ecoindex-cli/output/www.ecoindex.fr/2021-04-21_212127/index.html
When generating a html report, the results are written in a CSV file and you can not specify the result file location. So options
--export-format
and--output-file
are ignored.
Here is a sample result:
Only generate a report from existing result file
If you already performed an anlayzis and (for example), forgot to generate the html report, you do not need to re-run a full analyzis, you can simply request a report from your result file :
ecoindex-cli report "/tmp/ecoindex-cli/output/www.ecoindex.fr/2021-05-06_191355/results.csv" "www.synchrone.fr"
Result
🦄️ Amazing! A report has been generated to /tmp/ecoindex-cli/output/www.ecoindex.fr/2021-05-06_191355/index.html
Results example
The result of the analysis is a CSV or JSON file which can be easily used for further analysis:
CSV example
width,height,url,size,nodes,requests,grade,score,ges,water,date,page_type
1920,1080,http://www.ecoindex.fr,521.54,45,68,B,75.0,1.5,2.25,2022-05-03 22:28:49.280479,
1920,1080,https://www.greenit.fr,1374.641,666,167,E,32.0,2.36,3.54,2022-05-03 22:28:51.176216,website
JSON example
[
{
"width": 1920,
"height": 1080,
"url": "http://www.ecoindex.fr",
"size": 521.54,
"nodes": 45,
"requests": 68,
"grade": "B",
"score": 75.0,
"ges": 1.5,
"water": 2.25,
"date": "2022-05-03 22:25:01.016749",
"page_type": null
},
{
"width": 1920,
"height": 1080,
"url": "https://www.greenit.fr",
"size": 1163.386,
"nodes": 666,
"requests": 148,
"grade": "E",
"score": 34.0,
"ges": 2.32,
"water": 3.48,
"date": "2022-05-03 22:25:04.516676",
"page_type": "website"
}
]
Fields description
width
is the screen width used for the page analysis (in pixels)height
is the screen height used for the page analysis (in pixels)url
is the analysed page urlsize
is the size of the page and of the downloaded elements of the page in KBnodes
is the number of the DOM elements in the pagerequests
is the number of external requests made by the pagegrade
is the corresponding ecoindex grade of the page (from A to G)score
is the corresponding ecoindex score of the page (0 to 100)ges
is the equivalent of greenhouse gases emission (ingCO2e
) of the pagewater
is the equivalent water consumption (incl
) of the pagedate
is the datetime of the page analysispage_type
is the type of the page, based ton the opengraph type tag
Testing
In order to develop or test, you have to use Poetry, install the dependencies and execute a poetry shell:
poetry install && \
poetry shell
We use Pytest to run unit tests for this project. The test suite are in the tests
folder. Just execute :
pytest --cov-report term-missing:skip-covered --cov=. --cov-config=.coveragerc tests
This runs pytest and also generate a coverage report (terminal and html)
Disclaimer
The LCA values used by ecoindex_cli to evaluate environmental impacts are not under free license - ©Frédéric Bordage Please also refer to the mentions provided in the code files for specifics on the IP regime.
License
Contributing
Code of conduct
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ecoindex_cli-2.15.2.tar.gz
.
File metadata
- Download URL: ecoindex_cli-2.15.2.tar.gz
- Upload date:
- Size: 25.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.1 CPython/3.10.8 Linux/5.15.0-1024-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ddf10308519b3ed68b8502b09b0d63d0b84a88f12e5cd10d5871640bb74b6c6b |
|
MD5 | 253394eef52cfee89665a35c87da8db0 |
|
BLAKE2b-256 | 518f78e81a29304bd810e707e51f4f58521481c06afd840c4779cf65431a3356 |
File details
Details for the file ecoindex_cli-2.15.2-py3-none-any.whl
.
File metadata
- Download URL: ecoindex_cli-2.15.2-py3-none-any.whl
- Upload date:
- Size: 32.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.1 CPython/3.10.8 Linux/5.15.0-1024-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 37238f9f917c544c3348a4dd6fde5c22bd857b34a0b19dfa3539ad780192850f |
|
MD5 | fc1947946939ce1d489cf590b1831659 |
|
BLAKE2b-256 | bef340428f06349b9a5c3aeb04062a732c08d9b2375cba13aa37d3b2d690da5f |