mirror of
https://github.com/jrnl-org/jrnl.git
synced 2025-05-10 08:38:32 +02:00
* Encapsulate all multiline strings in triple-quotes in Gherkin files Since pytest-bdd v8.0.0 uses the official Gherkin parser, multiline strings must now be encapsulated by triple-quotes. See: - https://pytest-bdd.readthedocs.io/en/stable/#id2 - https://pytest-bdd.readthedocs.io/en/stable/#docstrings * Remove comments in Gherkin files causing test breakage These comments break the step matching. * Fix compatibility of step-functions matching on multiple lines In pytest-bdd v8.0.0 it is no longer possible to match based on multiple lines, which breaks essentially all steps that support docstrings. Solve this by adding a wrapper-function for each of these instances, that matches the docstring step, and calls the original function. So, what used to be: @then(parse("the output should match\n{regex}")) @then(parse('the output should match "{regex}"')) def output_should_match(regex, cli_run): ... Is now: @then(parse("the output should match")) def output_should_match_docstring(cli_run, docstring): output_should_match(docstring, cli_run) @then(parse('the output should match "{regex}"')) def output_should_match(regex, cli_run): ... There is possibly a way around this that is much better than what I've done here, but this is a start at least. * Update version requirement of pytest-bdd to >=8.0 * Update tox config to match poetry config --------- Co-authored-by: Micah Jerome Ellison <micah.jerome.ellison@gmail.com>
123 lines
4.5 KiB
Gherkin
123 lines
4.5 KiB
Gherkin
# Copyright © 2012-2023 jrnl contributors
|
|
# License: https://www.gnu.org/licenses/gpl-3.0.html
|
|
|
|
Feature: Multiple journals
|
|
|
|
Scenario: Loading a config with two journals
|
|
Given we use the config "multiple.yaml"
|
|
When we run "jrnl -99 --short"
|
|
Then the output should be
|
|
"""
|
|
2013-06-09 15:39 My first entry.
|
|
2013-06-10 15:40 Life is good.
|
|
"""
|
|
When we run "jrnl work -99 --short"
|
|
Then the output should be empty
|
|
|
|
Scenario: Write to default config by default
|
|
Given we use the config "multiple.yaml"
|
|
When we run "jrnl this goes to default"
|
|
When we run "jrnl -99 --short"
|
|
Then the output should contain
|
|
"""
|
|
2013-06-09 15:39 My first entry.
|
|
2013-06-10 15:40 Life is good.
|
|
"""
|
|
Then the output should contain
|
|
"""
|
|
this goes to default
|
|
"""
|
|
When we run "jrnl work -99 --short"
|
|
Then the output should be empty
|
|
|
|
Scenario: Write to specified journal
|
|
Given we use the config "multiple.yaml"
|
|
When we run "jrnl work a long day in the office"
|
|
When we run "jrnl -99 --short"
|
|
Then the output should be
|
|
"""
|
|
2013-06-09 15:39 My first entry.
|
|
2013-06-10 15:40 Life is good.
|
|
"""
|
|
When we run "jrnl work -99 --short"
|
|
Then the output should contain "a long day in the office"
|
|
|
|
Scenario: Tell user which journal was used
|
|
Given we use the config "multiple.yaml"
|
|
When we run "jrnl work a long day in the office"
|
|
Then the output should contain "Entry added to work journal"
|
|
|
|
Scenario: Write to specified journal with a timestamp
|
|
Given we use the config "multiple.yaml"
|
|
When we run "jrnl work 23 july 2012: a long day in the office"
|
|
When we run "jrnl -99 --short"
|
|
Then the output should be
|
|
"""
|
|
2013-06-09 15:39 My first entry.
|
|
2013-06-10 15:40 Life is good.
|
|
"""
|
|
When we run "jrnl work -99 --short"
|
|
Then the output should be
|
|
"""
|
|
2012-07-23 09:00 a long day in the office
|
|
"""
|
|
|
|
Scenario: Write to specified journal without a timestamp but with colon
|
|
Given we use the config "multiple.yaml"
|
|
When we run "jrnl work : a long day in the office"
|
|
Then the output should be
|
|
"""
|
|
2013-06-09 15:39 My first entry.
|
|
2013-06-10 15:40 Life is good.
|
|
"""
|
|
When we run "jrnl work -99 --short"
|
|
Then the output should be contain
|
|
"""
|
|
a long day in the office
|
|
"""
|
|
|
|
Scenario: Write to specified journal without a timestamp but with colon
|
|
Given we use the config "multiple.yaml"
|
|
When we run "jrnl work: a long day in the office"
|
|
When we run "jrnl -99 --short"
|
|
Then the output should be
|
|
"""
|
|
2013-06-09 15:39 My first entry.
|
|
2013-06-10 15:40 Life is good.
|
|
"""
|
|
When we run "jrnl work -99 --short"
|
|
Then the output should contain
|
|
"""
|
|
a long day in the office
|
|
"""
|
|
|
|
Scenario: Create new journals as required
|
|
Given we use the config "multiple.yaml"
|
|
Then journal "ideas" should not exist
|
|
When we run "jrnl ideas 23 july 2012: sell my junk on ebay and make lots of money"
|
|
When we run "jrnl ideas -99 --short"
|
|
Then the output should be
|
|
"""
|
|
2012-07-23 09:00 sell my junk on ebay and make lots of money
|
|
"""
|
|
|
|
Scenario: Don't crash if no default journal is specified
|
|
Given we use the config "no_default_journal.yaml"
|
|
When we run "jrnl a long day in the office"
|
|
Then the output should contain "No 'default' journal configured"
|
|
|
|
Scenario: Don't crash if no file exists for a configured encrypted journal
|
|
Given we use the config "multiple.yaml"
|
|
When we run "jrnl new_encrypted Adding first entry" and enter
|
|
"""
|
|
these three eyes
|
|
these three eyes
|
|
n
|
|
"""
|
|
Then the output should contain "Journal 'new_encrypted' created at"
|
|
|
|
Scenario: Read and write to journal with emoji name
|
|
Given we use the config "multiple.yaml"
|
|
When we run "jrnl ✨ Adding entry to sparkly journal"
|
|
When we run "jrnl ✨ -1"
|
|
Then the output should contain "Adding entry to sparkly journal"
|