1
0
Fork 0
mirror of https://github.com/borgbase/vorta synced 2025-01-03 05:36:19 +00:00

Unify task outline section to use the imperative (vorta).

real-yfprojects 2023-02-06 12:55:39 +01:00
parent 08d1a2c264
commit 5a109a3886
No known key found for this signature in database
GPG key ID: 00F630DFDEE25747

@ -51,7 +51,12 @@ These are tasks you can work on. You can combine any number of tasks, so they ad
**Length**: 175 hours<br /> **Length**: 175 hours<br />
**Skills required**: Python, Qt, Unix desktop<br /> **Skills required**: Python, Qt, Unix desktop<br />
**Description**: Currently users exclude files by adding text rules, like `/tmp/cache/*.tmp`. It is often confusing and we'd like to add a GUI, as well as pre-defined rules for it. E.g. one could choose to exclude common macOS cache files.<br /> **Description**: Currently users exclude files by adding text rules, like `/tmp/cache/*.tmp`. It is often confusing and we'd like to add a GUI, as well as pre-defined rules for it. E.g. one could choose to exclude common macOS cache files.<br />
**Task outline**: Create a list of sensible default files to exclude. Possibly grouped, so users can choose to enable parts of them. Decide on way to store exclusions, do mockup of GUI (partly done), implement as Qt UI file, implement parsing exclusion rules to Borg input.<br /> **Task outline**:
Create a list of sensible default files to exclude.
Possibly grouped, so users can choose to enable parts of them.
Decide on way to store exclusions.
Do mockup of GUI (partly done).
Implement as Qt UI file. Implement parsing exclusion rules to Borg input.<br />
**Additional details**: See [this issue](https://github.com/borgbase/vorta/issues/907) for discussions about the GUI part and [here](https://github.com/borgbase/vorta/issues/907#issuecomment-1282309557) for suggested exclusion rules.<br /> **Additional details**: See [this issue](https://github.com/borgbase/vorta/issues/907) for discussions about the GUI part and [here](https://github.com/borgbase/vorta/issues/907#issuecomment-1282309557) for suggested exclusion rules.<br />
**Possible mentors**: [@real-yfprojects][real-yfprojects], [@m3nu][m3nu], [@Hofer-Julian][Hofer-Julian] **Possible mentors**: [@real-yfprojects][real-yfprojects], [@m3nu][m3nu], [@Hofer-Julian][Hofer-Julian]
@ -77,7 +82,11 @@ Adjust the existing vorta code to use/work with the new dialog.<br />
**Length**: 25 hours<br /> **Length**: 25 hours<br />
**Skills required**: Python, Unix, OpenSSH<br /> **Skills required**: Python, Unix, OpenSSH<br />
**Description**: It's easy to add a dependency but hard to remove it. We found that it's not really essential for our application to parse each SSH key a user has. So this task would remove Paramiko and just do a rudimentary check to see if a file is a private SSH key.<br /> **Description**: It's easy to add a dependency but hard to remove it. We found that it's not really essential for our application to parse each SSH key a user has. So this task would remove Paramiko and just do a rudimentary check to see if a file is a private SSH key.<br />
**Task outline**: You will first research and confirm the format of OpenSSH keys. Then build a function to identify one, given a file path. Then use this function in place of Paramiko. Also includes test cases for all steps.<br /> **Task outline**:
Research and confirm the format of OpenSSH keys.
Build a function to identify one, given a file path.
Replace usage of Paramiko with this function.
Also includes test cases for all steps.<br />
**Additional details**: See [this issue](https://github.com/borgbase/vorta/issues/1559)<br /> **Additional details**: See [this issue](https://github.com/borgbase/vorta/issues/1559)<br />
**Possible mentors**: [@real-yfprojects][real-yfprojects], [@m3nu][m3nu], [@Hofer-Julian][Hofer-Julian] **Possible mentors**: [@real-yfprojects][real-yfprojects], [@m3nu][m3nu], [@Hofer-Julian][Hofer-Julian]
@ -86,7 +95,10 @@ Adjust the existing vorta code to use/work with the new dialog.<br />
**Length**: 90 hours<br /> **Length**: 90 hours<br />
**Skills required**: Python, Pytest<br /> **Skills required**: Python, Pytest<br />
**Description**: It's fun to add new features, but the actual work is maintaining them over time, as the code around it changes. This task would aim to increase the coverage output by the `coverage` tool from ~65% to ~80% by cleaning up existing tests, using parameterization and adding more unit tests (as opposed to higher-level integration tests we use now).<br /> **Description**: It's fun to add new features, but the actual work is maintaining them over time, as the code around it changes. This task would aim to increase the coverage output by the `coverage` tool from ~65% to ~80% by cleaning up existing tests, using parameterization and adding more unit tests (as opposed to higher-level integration tests we use now).<br />
**Task outline**: You will look at each Vorta package and module to find corresponding existing tests. Then use consistent file naming for existing tests and add missing tests (especially unit tests).<br /> **Task outline**:
Look at each Vorta package and module to find corresponding existing tests.
Analyse the test coverage and determine which additional tests are needed.
Then use consistent file naming for existing tests and add missing tests (especially unit tests).<br />
**Additional details**: TODO<br /> **Additional details**: TODO<br />
**Possible mentors**: [@real-yfprojects][real-yfprojects], [@m3nu][m3nu], [@Hofer-Julian][Hofer-Julian] **Possible mentors**: [@real-yfprojects][real-yfprojects], [@m3nu][m3nu], [@Hofer-Julian][Hofer-Julian]
@ -95,7 +107,9 @@ Adjust the existing vorta code to use/work with the new dialog.<br />
**Length**: 175 hours<br /> **Length**: 175 hours<br />
**Skills required**: Python, Unix, Shell<br /> **Skills required**: Python, Unix, Shell<br />
**Description**: Currently we test on static mock files of Borg JSON output. That means our tests don't actually run Borg, but take some existing output. This is not optimal because we already support 3 major Borg versions and can only add mock files for one. This task would improve testing to run on multiple actual Borg versions/binaries. <br /> **Description**: Currently we test on static mock files of Borg JSON output. That means our tests don't actually run Borg, but take some existing output. This is not optimal because we already support 3 major Borg versions and can only add mock files for one. This task would improve testing to run on multiple actual Borg versions/binaries. <br />
**Task outline**: You will build a testing utility that can run a Vorta tests on multiple versions of Borg. Maybe using Tox or some kind of script. (TODO: Expand)<br /> **Task outline**:
Research how to create multiple environments with different borg versions to run tests in. This might work differently in the CI (on the server) and local developer machines.
Build a testing utility that can run the existing Vorta tests on multiple versions of Borg. (You can use a tool like Tox or write your own script.)<br /> <!-- TODO: Expand? -->
**Additional details**: TODO<br /> **Additional details**: TODO<br />
**Possible mentors**: [@real-yfprojects][real-yfprojects], [@m3nu][m3nu], [@Hofer-Julian][Hofer-Julian] **Possible mentors**: [@real-yfprojects][real-yfprojects], [@m3nu][m3nu], [@Hofer-Julian][Hofer-Julian]