diff options
| -rw-r--r-- | continuedev/src/continuedev/tests/step_test.py | 55 | ||||
| -rw-r--r-- | continuedev/src/continuedev/tests/util/prompts.py | 3 | 
2 files changed, 42 insertions, 16 deletions
| diff --git a/continuedev/src/continuedev/tests/step_test.py b/continuedev/src/continuedev/tests/step_test.py index a4131e61..c9bb5441 100644 --- a/continuedev/src/continuedev/tests/step_test.py +++ b/continuedev/src/continuedev/tests/step_test.py @@ -2,8 +2,12 @@ import pytest  from continuedev.core.config import ContinueConfig  from continuedev.headless import start_headless_session +from continuedev.plugins.steps.main import EditHighlightedCodeStep  from continuedev.plugins.steps.core.core import UserInputStep -from continuedev.tests.util.prompts import tokyo_test_pair +from continuedev.plugins.steps.on_traceback import DefaultOnTracebackStep +from continuedev.tests.util.prompts import tokyo_test_pair, dotenv_test_pair +from continuedev.models.filesystem import RangeInFileWithContents, Range +from continuedev.plugins.steps.chat import SimpleChatStep  TEST_CONFIG = ContinueConfig() @@ -15,6 +19,15 @@ async def test_step():      await session.autopilot.run_from_step(UserInputStep(user_input=tokyo_test_pair[0]))      full_state = await session.autopilot.get_full_state() + +    assert ( +        isinstance(full_state.history.timeline[-1].step, SimpleChatStep) +    ) + +    assert ( +        not full_state.history.timeline[-1].step.hide +    ) +      assert (          full_state.history.timeline[-1].step.description.strip().lower()          == tokyo_test_pair[1] @@ -23,21 +36,33 @@ async def test_step():      await session.autopilot.cleanup() -# TODO: Test other properties of full_state after the UserInputStep. Also test with other config properties and models, etc... -# so we are sure that UserInputStep works in many cases. One example of a thing to check is that the step following UserInputStep -# is a SimpleChatStep, and that it is not hidden, and that the properties of the node (full_state.history.timeline[-1]) all look good -# (basically, run it, see what you get, then codify this in assertions) +@pytest.mark.asyncio +async def test_traceback_step(): +    session = await start_headless_session(config=TEST_CONFIG) -# TODO: Write tests for other steps: -# - DefaultOnTracebackStep -# - EditHighlightedCodeStep (note that this won't test the rendering in IDE) +    await session.autopilot.run_from_step(DefaultOnTracebackStep(output=dotenv_test_pair[0])) -# NOTE: Avoid expensive prompts - not too big a deal, but don't have it generate an entire 100 line file -# If you want to not have llm_test.py spend money, change SPEND_MONEY to False at the -# top of that file, but make sure to put it back to True before committing +    full_state = await session.autopilot.get_full_state() +    assert ( +        dotenv_test_pair[1] in full_state.history.timeline[-1].step.description +    ) -# NOTE: Headless mode uses continuedev.src.continuedev.headless.headless_ide instead of -# VS Code, so many of the methods just pass, or might not act exactly how you expect. -# See the file for reference +    await session.autopilot.cleanup() -# NOTE: If this is too short or pointless a task, let me know and I'll set up testing of ContextProviders + +@pytest.mark.asyncio +async def test_edit_step(): +    session = await start_headless_session(config=TEST_CONFIG) + +    range_in_file = RangeInFileWithContents(filepath=__file__, range=Range.from_shorthand(0, 0, 0, 0), contents="") + +    await session.autopilot.handle_highlighted_code(range_in_files=[range_in_file]) + +    await session.autopilot.run_from_step(EditHighlightedCodeStep(user_input="Don't edit this code")) + +    full_state = await session.autopilot.get_full_state() +    assert ( +        isinstance(full_state.history.timeline[-1].step.description, str) +    ) + +    await session.autopilot.cleanup() diff --git a/continuedev/src/continuedev/tests/util/prompts.py b/continuedev/src/continuedev/tests/util/prompts.py index f60c926c..e84ddc82 100644 --- a/continuedev/src/continuedev/tests/util/prompts.py +++ b/continuedev/src/continuedev/tests/util/prompts.py @@ -1 +1,2 @@ -tokyo_test_pair = ("Output a single word, that being the capital of Japan:", "tokyo")
\ No newline at end of file +tokyo_test_pair = ("Output a single word, that being the capital of Japan:", "tokyo") +dotenv_test_pair = ("ModuleNotFoundError: No module named 'dotenv'", "python-dotenv")
\ No newline at end of file | 
