Introduce TestOption Enum for Enhanced Test Selection Clarity (#5586)

This commit is contained in:
hunteraraujo
2023-10-06 16:13:33 -07:00
committed by GitHub
parent 0f2126e6f0
commit b2d53d8d18
4 changed files with 95 additions and 25 deletions

View File

@@ -1,4 +1,5 @@
import 'package:auto_gpt_flutter_client/models/benchmark/benchmark_task_status.dart';
import 'package:auto_gpt_flutter_client/models/test_option.dart';
import 'package:auto_gpt_flutter_client/viewmodels/chat_viewmodel.dart';
import 'package:auto_gpt_flutter_client/viewmodels/task_viewmodel.dart';
import 'package:auto_gpt_flutter_client/views/task_queue/leaderboard_submission_button.dart';
@@ -98,11 +99,11 @@ class TaskQueueView extends StatelessWidget {
// TestSuiteButton
TestSuiteButton(
isDisabled: viewModel.isBenchmarkRunning,
selectedOption: viewModel.selectedOption,
selectedOptionString: viewModel.selectedOption.description,
onOptionSelected: (selectedOption) {
print('Option Selected: $selectedOption');
viewModel.updateSelectedNodeHierarchyBasedOnOption(
selectedOption);
TestOptionExtension.fromDescription(selectedOption)!);
},
onPlayPressed: (selectedOption) {
print('Starting benchmark with option: $selectedOption');

View File

@@ -1,17 +1,18 @@
import 'package:auto_gpt_flutter_client/constants/app_colors.dart';
import 'package:auto_gpt_flutter_client/models/test_option.dart';
import 'package:flutter/material.dart';
class TestSuiteButton extends StatefulWidget {
final bool isDisabled;
final Function(String) onOptionSelected;
final Function(String) onPlayPressed;
String selectedOption;
String selectedOptionString;
TestSuiteButton({
this.isDisabled = false,
required this.onOptionSelected,
required this.onPlayPressed,
required this.selectedOption,
required this.selectedOptionString,
});
@override
@@ -30,24 +31,27 @@ class _TestSuiteButtonState extends State<TestSuiteButton> {
enabled: !widget.isDisabled,
onSelected: (value) {
setState(() {
widget.selectedOption = value;
widget.selectedOptionString = value;
});
widget.onOptionSelected(widget.selectedOption);
widget.onOptionSelected(widget.selectedOptionString);
},
itemBuilder: (BuildContext context) {
return [
const PopupMenuItem(
value: 'Run single test',
child: Text('Run single test'),
PopupMenuItem(
value: TestOption.runSingleTest.description,
child: Text(TestOption.runSingleTest.description),
),
const PopupMenuItem(
value: 'Run test suite including selected node and ancestors',
child: Text(
'Run test suite including selected node and ancestors'),
PopupMenuItem(
value: TestOption
.runTestSuiteIncludingSelectedNodeAndAncestors
.description,
child: Text(TestOption
.runTestSuiteIncludingSelectedNodeAndAncestors
.description),
),
const PopupMenuItem(
value: 'Run all tests in category',
child: Text('Run all tests in category'),
PopupMenuItem(
value: TestOption.runAllTestsInCategory.description,
child: Text(TestOption.runAllTestsInCategory.description),
),
];
},
@@ -63,7 +67,7 @@ class _TestSuiteButtonState extends State<TestSuiteButton> {
children: [
Flexible(
child: Text(
widget.selectedOption,
widget.selectedOptionString,
style: const TextStyle(
color: Colors.white,
fontSize: 12.50,
@@ -100,7 +104,7 @@ class _TestSuiteButtonState extends State<TestSuiteButton> {
onPressed: widget.isDisabled
? null
: () {
widget.onPlayPressed(widget.selectedOption);
widget.onPlayPressed(widget.selectedOptionString);
},
child: const Icon(
Icons.play_arrow,