From c2f07454608474398ea0b7166098a194b513b2ac Mon Sep 17 00:00:00 2001 From: Clare Macrae Date: Thu, 9 Jan 2025 20:15:40 +0000 Subject: [PATCH] vault: Revert temporary edits to 'Smoke Testing the Tasks Plugin.md' --- .../Smoke Testing the Tasks Plugin.md | 173 +++++++++++++++++- 1 file changed, 171 insertions(+), 2 deletions(-) diff --git a/resources/sample_vaults/Tasks-Demo/Manual Testing/Smoke Testing the Tasks Plugin.md b/resources/sample_vaults/Tasks-Demo/Manual Testing/Smoke Testing the Tasks Plugin.md index 97efd64c4b..6eb4916ecf 100644 --- a/resources/sample_vaults/Tasks-Demo/Manual Testing/Smoke Testing the Tasks Plugin.md +++ b/resources/sample_vaults/Tasks-Demo/Manual Testing/Smoke Testing the Tasks Plugin.md @@ -1,6 +1,86 @@ # Smoke Testing the Tasks Plugin -## Toggling tasks - Recurring Tasks +*[[#Remaining tests|Jump to the tests...]]* + +## Introduction + +- **Intended audience of this note** + - Developers working on the Tasks plugin, reviewing a Pull Request (especially ones that change dependencies), or making a release, and who wish to do some basic tests of the plugin to make sure there are no glaring show-stopper errors. +- **What is a Smoke Test?** + - As [Wikipedia](https://en.wikipedia.org/wiki/Smoke_testing_(software)) says: smoke testing ... is preliminary testing to reveal simple failures severe enough to, for example, reject a prospective software release. +- **Why not test everything?** + - The Tasks plugin is run by volunteers in our finite spare time. We take care during development to write automated tests for the algorithms in our code, but there are some kinds of changes, such as in tools the project depends on, that we do not have automated tests for. +- **Why not test on every platform?** + - It's not feasible nor a good use of limited volunteer time on a free tool. + +## How the tests work + +### Get the Tasks-Demo vault with the build to be tested + +You can either [download the Tasks-demo vault with the build's Tasks plugin installed](https://publish.obsidian.md/tasks-contributing/Testing/How+do+I+test+a+GitHub+build+of+the+Tasks+plugin) - see Option 1. + +Or you can install a download of the build's Tasks plugin inside your clone of the Tasks repo: + +- Make sure you have the [obsidian-tasks repo](https://github.com/obsidian-tasks-group/obsidian-tasks) cloned and up-to-date on your machine. +- Open the Tasks-Demo vault on a machine of your choice: + - Open Obsidian + - Click 'Open another vault' button + - Click 'Open folder as vault' button + - Navigate to `obsidian-tasks/resources/sample_vaults/Tasks-Demo` + - Click 'Open' +- Install the candidate build for the pull request or release inside the `Tasks-Demo` vault + - See [How do I test a GitHub build of the Tasks plugin](https://publish.obsidian.md/tasks-contributing/Testing/How+do+I+test+a+GitHub+build+of+the+Tasks+plugin) - see Option 2. + +### Follow the tests + +- This note is a self-contained set of steps to check. You should check off tasks beginning `- [ ] check:` as you complete each section. + +> [!Important] +> Several task blocks in this file depend of the the file name being unchanged. Please don't rename the file before running the tests. + +--- + +## Remaining tests + +Work through all the tasks below, until zero tasks remain in this query: + +> [!Todo] Remaining groups of tests +> +> ```tasks +> not done +> path includes Smoke Testing the Tasks Plugin +> description includes **check**: +> +> short display +> ``` + +--- + +## The Smoke Tests + +### Toggling tasks + +#### Completion of tasks + +- [ ] #task Mark this task complete in **Source view** using **Tasks: Toggle task done** command +- [ ] #task Mark this task complete by clicking on it in **Reading view** +- [ ] #task Mark this task complete by clicking on it in **Live Preview** - ==ensure the checkbox is redrawn correctly== +- [ ] #task **check**: Checked all above methods for **completing tasks** - and they worked + +#### Un-completion of tasks + + + +* [x] #task Mark this task not complete in **Source view** using **Tasks: Toggle task done** command ✅ 2022-07-05 +* [x] #task Mark this task not complete by clicking on it in **Reading view** ✅ 2022-07-05 +* [x] #task Mark this task not complete by clicking on it in **Live Preview** - ==ensure the checkbox is redrawn correctly== ✅ 2022-07-05 +* [ ] #task **check**: Checked all above methods for **un-completing tasks** - and they worked + + + +#### Recurring Tasks + +Confirm that when a recurring task is completed, a new task is created, all the date fields are incremented, and the indentation is unchanged. > [!Todo] > @@ -12,9 +92,56 @@ > - [ ] #task **check**: Checked all above steps for **recurring tasks** worked +### On Completion + +#### On Completion Delete: Non-recurring tasks + +Confirm that the **task line is deleted**. + +- [ ] #task Complete this auto-deleting non-recurring task in **Source view** using **Tasks: Toggle task done** command 🏁 delete 📅 2024-10-27 +- [ ] #task Complete this auto-deleting non-recurring task in **Reading view** 🏁 delete 📅 2024-10-27 +- [ ] #task Complete this auto-deleting non-recurring task in **Live Preview** 🏁 delete 📅 2024-10-27 +- [ ] #task **check**: Checked all above steps for **auto-deleting non-recurring tasks** worked + +#### On Completion Delete: Recurring Tasks + +Confirm that when an auto-deleting recurring task is completed, a **new task is created replacing the old task**, and the checkbox remains not-done. + +- [ ] #task Complete this auto-deleting recurring task in **Source view** using **Tasks: Toggle task done** command 🔁 every day 🏁 delete 📅 2024-10-27 +- [ ] #task Complete this auto-deleting recurring task in **Reading view** 🔁 every day 🏁 delete 📅 2024-10-27 +- [ ] #task Complete this auto-deleting recurring task in **Live Preview** - ==ensure the checkbox is redrawn correctly== 🔁 every day 🏁 delete 📅 2024-10-27 +- [ ] #task **check**: Checked all above steps for **auto-deleting recurring tasks** worked + +### Rendering of Task Blocks + +Steps to do: + + + ++ [ ] #task View this file in **Reading view** and confirm that the tasks in this section are listed ++ [ ] #task View this file in **Live Preview** and confirm that the tasks in this section are listed ++ [ ] #task **check**: Checked all above steps for **viewing task blocks** worked + + + --- -## Edit dates in Rendered Task Blocks +Tasks block to check - should list all the tasks in this section, regardless of state + +```tasks +path includes Smoke Testing the Tasks Plugin +heading includes Rendering of Task Blocks +``` + +--- + +### Styling of Rendered Task Blocks + +- [ ] #task **check**: Open the file [[Styling of Queries]] and follow the steps there + +--- + +### Edit dates in Rendered Task Blocks > [!Example] > @@ -23,8 +150,14 @@ - View this file in **Reading mode**... - On the task line above: - [ ] #task **left**-click on a date value, and use the date picker to select and save a different date. Check that the date is updated. + - [ ] #task **left**-click on a date value, and click outside the date picker, to confirm that the picker closes. + - [ ] #task **right**-click on a date value, and use the context menu to select and save a different date. Check that the date is updated. + - [ ] #task **right**-click on a date value, and click outside the context menu, to confirm that the menu closes. - In the tasks search block below: - [ ] #task **left**-click on a date value, and use the date picker to select and save a different date. Check that the date is updated. + - [ ] #task **left**-click on a date value, and click outside the date picker, to confirm that the picker closes. + - [ ] #task **right**-click on a date value, and use the context menu to select and save a different date. Check that the date is updated. + - [ ] #task **right**-click on a date value, and click outside the context menu, to confirm that the menu closes. - [ ] #task **check**: Checked all above steps for **editing dates** worked ```tasks @@ -33,3 +166,39 @@ description includes I have all the supported date types hide backlink hide postpone button ``` + +--- + +### Create or edit Task modal + +- This text should copied in to the task Description, after following steps below +- [ ] #task Switch to **Live Preview** or **Source mode**, Click on the list item above, then do the following numbered steps and checks: + 1. run **Tasks: Create or edit task** + 2. **Check** that the text in the list item is copied in to the Description field + 3. Type some values in to the fields + 4. In one of the date fields, type `tm` (including the space afterwards) and **Check** it is expanded in to `tomorrow` + 5. In one of the date fields, left-click the calendar button, and use the context menu to select and save a date. Check that the date is saved. + 6. In one of the date fields, left-click the calendar button, and click outside the date picker, to confirm that the picker closes and the modal is still usable. + 7. Hit Return or click **Apply** + 8. **Check** that the list item above is converted in to a task + 9. **Check** that values you entered in the modal have been copied in to the list item above + 10. **Check** that the `#task` tag has been added to the start of the task +- [ ] #task **check**: Checked all above steps for **creating a task via the modal** worked + +--- + +## Check the plugin starts OK with no `data.json` settings file + +- Preparation + - Go to Settings -> Community plugins -> Installed plugins -> click on the folder icon to **Open plugins folder** + - Quit Obsidian + - Open the `obsidian-tasks-plugin` folder + - Delete `data.json` +- Test + - Restart obsidian + - Go to Settings + - Check that `Tasks` is shown in the list of **Community plugins** + - View -> Toggle Developer Tools + - Open the console + - Confirm that there are no red messages mentioning Tasks +- [ ] #task **check**: Checked that Tasks works correctly when **there is no `data.json` present**