mirror of
https://github.com/foss42/apidash.git
synced 2025-07-01 13:37:54 +08:00
generateTestCases prompting improved for structured responses
This commit is contained in:
@ -10,7 +10,7 @@ class OllamaService {
|
|||||||
Future<String> generateResponse(String prompt) async {
|
Future<String> generateResponse(String prompt) async {
|
||||||
final response = await _client.generateCompletion(
|
final response = await _client.generateCompletion(
|
||||||
request: GenerateCompletionRequest(
|
request: GenerateCompletionRequest(
|
||||||
model: 'llama3.2:3b',
|
model: 'llama3.2:1b',
|
||||||
prompt: prompt
|
prompt: prompt
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
@ -112,35 +112,25 @@ Analysis: [structured analysis]''';
|
|||||||
final headers = requestModel.httpRequestModel?.enabledHeadersMap ?? {};
|
final headers = requestModel.httpRequestModel?.enabledHeadersMap ?? {};
|
||||||
final parameters = requestModel.httpRequestModel?.enabledParamsMap ?? {};
|
final parameters = requestModel.httpRequestModel?.enabledParamsMap ?? {};
|
||||||
final body = requestModel.httpRequestModel?.body;
|
final body = requestModel.httpRequestModel?.body;
|
||||||
|
final responsebody=responseModel.body;
|
||||||
final exampleParams = await generateExampleParams(
|
final exampleParams = await generateExampleParams(
|
||||||
requestModel: requestModel,
|
requestModel: requestModel,
|
||||||
responseModel: responseModel,
|
responseModel: responseModel,
|
||||||
);
|
);
|
||||||
final prompt = '''
|
final prompt = '''
|
||||||
Generate test cases for the following API:
|
|
||||||
|
|
||||||
**API Request:**
|
**API Request:**
|
||||||
- **Endpoint:** `$endpoint`
|
- **Endpoint:** `$endpoint`
|
||||||
- **Method:** `$method`
|
- **Method:** `$method`
|
||||||
- **Headers:** ${headers.isNotEmpty ? jsonEncode(headers) : "None"}
|
- **Headers:** ${headers.isNotEmpty ? jsonEncode(headers) : "None"}
|
||||||
- **Parameters:** ${parameters.isNotEmpty ? jsonEncode(parameters) : "None"}
|
- **Parameters:** ${parameters.isNotEmpty ? jsonEncode(parameters) : "None"}
|
||||||
|
-**body:** ${body ?? "None"}
|
||||||
|
|
||||||
**Test Case Requirements:**
|
here is an example test case for the given:$exampleParams
|
||||||
1. Normal case (valid input, expected success)
|
|
||||||
2. Edge case (unexpected or boundary values)
|
|
||||||
3. Missing required parameters
|
|
||||||
4. Invalid authentication (if applicable)
|
|
||||||
5. Error handling for different status codes
|
|
||||||
|
|
||||||
**Example Test Case Format:**
|
**Instructions:**
|
||||||
@Test
|
- Generate example parameter values for the request.
|
||||||
void testValidRequest() {
|
-Generate the url of as i provided in the api reuest
|
||||||
final response = sendRequest("$endpoint", method: "$method", params: $exampleParams);
|
-generate same to same type of test case url for test purpose
|
||||||
assert(response.status == 200);
|
|
||||||
}
|
|
||||||
\`\`\`
|
|
||||||
|
|
||||||
Generate test cases covering all scenarios.
|
|
||||||
''';
|
''';
|
||||||
|
|
||||||
return generateResponse(prompt);
|
return generateResponse(prompt);
|
||||||
@ -177,15 +167,12 @@ Analyze the following API request and generate structured example parameters.
|
|||||||
- **Parameters:** ${parameters.isNotEmpty ? jsonEncode(parameters) : "None"}
|
- **Parameters:** ${parameters.isNotEmpty ? jsonEncode(parameters) : "None"}
|
||||||
- **Body:** ${body ?? "None"}
|
- **Body:** ${body ?? "None"}
|
||||||
|
|
||||||
**Response:**
|
|
||||||
- **Status Code:** ${responseModel?.statusCode ?? "Unknown"}
|
|
||||||
- **Response Body:** ${apiResponse != null ? jsonEncode(apiResponse) : rawResponse}
|
|
||||||
|
|
||||||
### **Required Output Format**
|
**Instructions:**
|
||||||
1. **Standard Example Values**: Assign the most appropriate example values for each parameter.
|
- Generate example parameter values for the request.
|
||||||
2. **Edge Cases**: Provide at least 2 edge cases per parameter.
|
-Generate the url of as i provided in the api reuest
|
||||||
3. **Invalid Cases**: Generate invalid inputs for error handling.
|
generate same to same type of test case url for test purpose
|
||||||
4. **Output must be in valid JSON format.**
|
|
||||||
''';
|
''';
|
||||||
|
|
||||||
// Force LLM to return structured JSON output
|
// Force LLM to return structured JSON output
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||||
import 'package:apidash/providers/providers.dart';
|
import 'package:apidash/providers/providers.dart';
|
||||||
|
import 'package:flutter_markdown/flutter_markdown.dart';
|
||||||
|
|
||||||
|
|
||||||
class ChatbotWidget extends ConsumerStatefulWidget {
|
class ChatbotWidget extends ConsumerStatefulWidget {
|
||||||
const ChatbotWidget({Key? key}) : super(key: key);
|
const ChatbotWidget({Key? key}) : super(key: key);
|
||||||
@ -90,20 +92,13 @@ class _ChatbotWidgetState extends ConsumerState<ChatbotWidget> {
|
|||||||
onPressed: () => _sendMessage("Debug API"),
|
onPressed: () => _sendMessage("Debug API"),
|
||||||
icon: const Icon(Icons.bug_report),
|
icon: const Icon(Icons.bug_report),
|
||||||
label: const Text("Debug"),
|
label: const Text("Debug"),
|
||||||
style: ElevatedButton.styleFrom(
|
|
||||||
backgroundColor: Colors.redAccent,
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
const Spacer(),
|
|
||||||
const SizedBox(width: 8),
|
const SizedBox(width: 8),
|
||||||
ElevatedButton.icon(
|
ElevatedButton.icon(
|
||||||
onPressed: () => _sendMessage("Generate Test Case"),
|
onPressed: () => _sendMessage("Generate Test Case"),
|
||||||
icon: const Icon(Icons.developer_mode),
|
icon: const Icon(Icons.developer_mode),
|
||||||
label: const Text("Test Case"),
|
label: const Text("Test Case"),
|
||||||
style: ElevatedButton.styleFrom(
|
|
||||||
backgroundColor: Colors.blueAccent,
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
|
|
||||||
const Spacer(),
|
const Spacer(),
|
||||||
@ -171,7 +166,10 @@ class ChatBubble extends StatelessWidget {
|
|||||||
: Theme.of(context).colorScheme.secondaryContainer,
|
: Theme.of(context).colorScheme.secondaryContainer,
|
||||||
borderRadius: BorderRadius.circular(8),
|
borderRadius: BorderRadius.circular(8),
|
||||||
),
|
),
|
||||||
child: Text(message),
|
child: MarkdownBody(
|
||||||
|
data: message,
|
||||||
|
selectable: true, // Allows copying text
|
||||||
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user