fix: correct behaviour of code fix (#24152)

Co-authored-by: Joel <iamjoel007@gmail.com>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
This commit is contained in:
Stream
2025-08-19 14:18:49 +08:00
committed by GitHub
parent 70da81d0e5
commit c2606f9062
3 changed files with 8 additions and 7 deletions

View File

@@ -12,7 +12,6 @@ from controllers.console.app.error import (
) )
from controllers.console.wraps import account_initialization_required, setup_required from controllers.console.wraps import account_initialization_required, setup_required
from core.errors.error import ModelCurrentlyNotSupportError, ProviderTokenNotInitError, QuotaExceededError from core.errors.error import ModelCurrentlyNotSupportError, ProviderTokenNotInitError, QuotaExceededError
from core.helper.code_executor.code_node_provider import CodeNodeProvider
from core.helper.code_executor.javascript.javascript_code_provider import JavascriptCodeProvider from core.helper.code_executor.javascript.javascript_code_provider import JavascriptCodeProvider
from core.helper.code_executor.python3.python3_code_provider import Python3CodeProvider from core.helper.code_executor.python3.python3_code_provider import Python3CodeProvider
from core.llm_generator.llm_generator import LLMGenerator from core.llm_generator.llm_generator import LLMGenerator
@@ -126,11 +125,13 @@ class InstructionGenerateApi(Resource):
parser.add_argument("model_config", type=dict, required=True, nullable=False, location="json") parser.add_argument("model_config", type=dict, required=True, nullable=False, location="json")
parser.add_argument("ideal_output", type=str, required=False, default="", location="json") parser.add_argument("ideal_output", type=str, required=False, default="", location="json")
args = parser.parse_args() args = parser.parse_args()
providers: list[type[CodeNodeProvider]] = [Python3CodeProvider, JavascriptCodeProvider] code_template = (
code_provider: type[CodeNodeProvider] | None = next( Python3CodeProvider.get_default_code()
(p for p in providers if p.is_accept_language(args["language"])), None if args["language"] == "python"
else (JavascriptCodeProvider.get_default_code())
if args["language"] == "javascript"
else ""
) )
code_template = code_provider.get_default_code() if code_provider else ""
try: try:
# Generate from nothing for a workflow node # Generate from nothing for a workflow node
if (args["current"] == code_template or args["current"] == "") and args["node_id"] != "": if (args["current"] == code_template or args["current"] == "") and args["node_id"] != "":

View File

@@ -414,7 +414,7 @@ When you are modifying the code, you should remember:
- Get inputs from the parameters of the function and have explicit type annotations. - Get inputs from the parameters of the function and have explicit type annotations.
- Write proper imports at the top of the code. - Write proper imports at the top of the code.
- Use return statement to return the result. - Use return statement to return the result.
- You should return a `dict`. - You should return a `dict`. If you need to return a `result: str`, you should `return {"result": result}`.
Your output must strictly follow the schema format, do not output any content outside of the JSON body. Your output must strictly follow the schema format, do not output any content outside of the JSON body.
""" # noqa: E501 """ # noqa: E501

View File

@@ -142,7 +142,7 @@ export const GetCodeGeneratorResModal: FC<IGetCodeGeneratorResProps> = (
ideal_output: ideaOutput, ideal_output: ideaOutput,
language: languageMap[codeLanguages] || 'javascript', language: languageMap[codeLanguages] || 'javascript',
}) })
if(!currentCode) if((res as any).code) // not current or current is the same as the template would return a code field
res.modified = (res as any).code res.modified = (res as any).code
if (error) { if (error) {