SoK/2023/StatusReport/Mohamed Ibrahim: Difference between revisions
Added background info and weekly summaries template |
|||
(6 intermediate revisions by 2 users not shown) | |||
Line 5: | Line 5: | ||
'''Introduction and Abstract:''' | '''Introduction and Abstract:''' | ||
[https://community.kde.org/Goals/Sustainable_Software Sustainability] is one of KDE's goals for the next two years. One aspect of this goal is to measure the energy consumption of KDE software. To do this, it is necessary to use an emulation tool to create usage scenario scripts. [https://invent.kde.org/teams/eco/feep/-/blob/master/tools/KdeEcoTest/ "KDE Eco Test"] is one such tool, but it needs some fixes. A list of to-dos can be found at the repository's [https://invent.kde.org/teams/eco/feep/-/blob/master/tools/KdeEcoTest/README.md README. | [https://community.kde.org/Goals/Sustainable_Software Sustainability] is one of KDE's goals for the next two years. One aspect of this goal is to measure the energy consumption of KDE software. To do this, it is necessary to use an emulation tool to create usage scenario scripts. [https://invent.kde.org/teams/eco/feep/-/blob/master/tools/KdeEcoTest/ "KDE Eco Test"] is one such tool, but it needs some fixes. A list of to-dos can be found at the repository's [https://invent.kde.org/teams/eco/feep/-/blob/master/tools/KdeEcoTest/README.md README]. | ||
'''Mentor:''' | '''Mentor:''' | ||
Line 11: | Line 11: | ||
'''Blog Posts:''' | '''Blog Posts:''' | ||
* [https://eco.kde.org/blog/2023-04-14-sok23-eco-tester/ Improvements To KdeEcoTest] | |||
===== Weekly Progress ===== | |||
'''WEEKS 1 - 2''': I familiarized myself with using the KDE Eco Tester tool by testing some applications and creating small scripts, reading and understanding the code base in more detail before starting to refactor it. I also started working on maintainability issues by adding the support of a modern dependency manager for python [https://pipenv.pypa.io/en/latest/index.html (Pipenv)]. I also added a code formatter to make the code consistent by using [https://black.readthedocs.io/en/stable/ (Black)]. | |||
'''WEEKS 3 - 4''': I worked on redesign the current code base to make it more organized and maintainable. By fixing all the the warnings to follow [https://pep8.org/ PEP8], adding more encapsulation for the core parts (parser, runner, cli, creator, actions) by using classes, making the code fully typed with python type hints which makes developing experience better and reduces error, created a new rich CLI interface for the tool using [https://typer.tiangolo.com/ typer] and finally created a support for running testing multiple times with “repeatFunction” action. | |||
'''WEEKS 5 - 6''': I started exploring and learning the [https://python-prompt-toolkit.readthedocs.io/en/master/ python-prompt-toolkit] and InquirerPy packages to add support for an interactive script creator. The [http://Inquirerpy.readthedocs.io/ InquirerPy] package was limited and should be used as a standalone cli app instead of being added to a bigger full-screen app. I also worked in formatting the log files that are produced while running test scripts to follow the [https://eco.kde.org/handbook/#log-file-of-actions OSCAR] format . | |||
'''WEEKS 7 - 8''': I worked on supporting actions on modal windows that happen during recording scripts, for example, the file explorer that appears when saving a file. I also made the logs in a format that is compatible with the OSCAR tool. I also added formatted run-time logs using Loguru. | |||
'''WEEKS | '''WEEKS 9 - 10''': These past few weeks, I have worked on debugging the problem of sharing scripts between systems to see what makes scripts run on one machine but not on another. I took Gcompris as an example and worked with Rudrakshkarpe to test a script recorded on my machine. We found that screen resolution, font size, configuration files, side effects from previous tests, and different versions of the software can affect the sharing scripts. I also worked on fixing some bugs in the OSCAR format and the previous modal window solution. | ||
'''WEEKS | '''WEEKS 11 - 12''': During these weeks, I worked on simulating mouse dragging during running tests by enabling users to add a start and end point while building the scenario script, then a linear drag is performed while running. I also added support for listening for keyboard activity during recording and playing the recorded key press during a run using pynput. | ||
===== Merge Requests ===== | |||
* [https://invent.kde.org/teams/eco/feep/-/merge_requests/23 Merge request for updating installation docs] | |||
* [https://invent.kde.org/teams/eco/feep/-/merge_requests/26 Merge request for KdeEcoTest runner refactoring and manintenance] | |||
* [https://invent.kde.org/teams/eco/feep/-/merge_requests/29 Merge request for supporting modal Windows] | |||
* [https://invent.kde.org/teams/eco/feep/-/merge_requests/31 Merge request for adding OSCAR format and runtime logs] | |||
* [https://invent.kde.org/teams/eco/feep/-/merge_requests/33 Merge request for updating usage of the new CLI tool] | |||
* [https://invent.kde.org/teams/eco/feep/-/merge_requests/35 Merge request for adding keyboard activity] | |||
* [https://invent.kde.org/teams/eco/feep/-/merge_requests/37 Merge request for simulating mouse dragging] | |||
'''CONTACT ME:''' | '''CONTACT ME:''' | ||
I am available on Matrix: @hemasonus01:matrix.org | I am available on Matrix: @hemasonus01:matrix.org |
Latest revision as of 02:59, 16 April 2023
Improve "KDE Eco Test" emulation tool
Project type: Coding
Introduction and Abstract: Sustainability is one of KDE's goals for the next two years. One aspect of this goal is to measure the energy consumption of KDE software. To do this, it is necessary to use an emulation tool to create usage scenario scripts. "KDE Eco Test" is one such tool, but it needs some fixes. A list of to-dos can be found at the repository's README.
Mentor: Karanjot Singh @drquark:kde.org, Emmanuel Charruau @allon:kde.org, and Joseph P. De Veaugh-Geiss @joseph:kde.org on Matrix
Blog Posts:
Weekly Progress
WEEKS 1 - 2: I familiarized myself with using the KDE Eco Tester tool by testing some applications and creating small scripts, reading and understanding the code base in more detail before starting to refactor it. I also started working on maintainability issues by adding the support of a modern dependency manager for python (Pipenv). I also added a code formatter to make the code consistent by using (Black).
WEEKS 3 - 4: I worked on redesign the current code base to make it more organized and maintainable. By fixing all the the warnings to follow PEP8, adding more encapsulation for the core parts (parser, runner, cli, creator, actions) by using classes, making the code fully typed with python type hints which makes developing experience better and reduces error, created a new rich CLI interface for the tool using typer and finally created a support for running testing multiple times with “repeatFunction” action.
WEEKS 5 - 6: I started exploring and learning the python-prompt-toolkit and InquirerPy packages to add support for an interactive script creator. The InquirerPy package was limited and should be used as a standalone cli app instead of being added to a bigger full-screen app. I also worked in formatting the log files that are produced while running test scripts to follow the OSCAR format .
WEEKS 7 - 8: I worked on supporting actions on modal windows that happen during recording scripts, for example, the file explorer that appears when saving a file. I also made the logs in a format that is compatible with the OSCAR tool. I also added formatted run-time logs using Loguru.
WEEKS 9 - 10: These past few weeks, I have worked on debugging the problem of sharing scripts between systems to see what makes scripts run on one machine but not on another. I took Gcompris as an example and worked with Rudrakshkarpe to test a script recorded on my machine. We found that screen resolution, font size, configuration files, side effects from previous tests, and different versions of the software can affect the sharing scripts. I also worked on fixing some bugs in the OSCAR format and the previous modal window solution.
WEEKS 11 - 12: During these weeks, I worked on simulating mouse dragging during running tests by enabling users to add a start and end point while building the scenario script, then a linear drag is performed while running. I also added support for listening for keyboard activity during recording and playing the recorded key press during a run using pynput.
Merge Requests
- Merge request for updating installation docs
- Merge request for KdeEcoTest runner refactoring and manintenance
- Merge request for supporting modal Windows
- Merge request for adding OSCAR format and runtime logs
- Merge request for updating usage of the new CLI tool
- Merge request for adding keyboard activity
- Merge request for simulating mouse dragging
CONTACT ME:
I am available on Matrix: @hemasonus01:matrix.org