Integration tests (#1182)

* some integration tests

* more integration tests

* more tests

* update integration tests

* format
This commit is contained in:
Dawood Khan 2022-05-27 04:53:50 -04:00 committed by GitHub
parent d117ad0049
commit 2eaf61cf76
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
21 changed files with 8200 additions and 87 deletions

88
blocks_inputs Normal file
View File

@ -0,0 +1,88 @@
{
"mode": "blocks",
"components": [
{
"id": 1,
"type": "textbox",
"props": {
"lines": 5,
"max_lines": 20,
"default_value": "",
"label": "Input",
"show_label": true,
"name": "textbox",
"css": {}
}
},
{
"id": 2,
"type": "textbox",
"props": {
"lines": 1,
"max_lines": 20,
"default_value": "",
"label": "Output",
"show_label": true,
"name": "textbox",
"css": {}
}
},
{
"id": 3,
"type": "textbox",
"props": {
"lines": 1,
"max_lines": 20,
"default_value": "Hello friends\nhello friends\n\nHello friends\n\n",
"label": "Output",
"show_label": true,
"name": "textbox",
"css": {}
}
},
{
"id": 4,
"type": "button",
"props": {
"default_value": "Submit",
"name": "button",
"css": {}
}
}
],
"theme": "default",
"enable_queue": false,
"layout": {
"id": 0,
"children": [
{
"id": 1
},
{
"id": 2
},
{
"id": 3
},
{
"id": 4
}
]
},
"dependencies": [
{
"targets": [
4
],
"trigger": "click",
"inputs": [
1
],
"outputs": [
2
],
"status_tracker": null,
"queue": null
}
]
}

291
blocks_xray Normal file
View File

@ -0,0 +1,291 @@
{
"mode": "blocks",
"components": [
{
"id": 1,
"type": "markdown",
"props": {
"default_value": "<h1>Detect Disease From Scan</h1>\n<p>With this model you can lorem ipsum</p>\n<ul>\n<li>ipsum 1</li>\n<li>ipsum 2</li>\n</ul>\n",
"name": "markdown",
"css": {}
}
},
{
"id": 2,
"type": "checkboxgroup",
"props": {
"choices": [
"Covid",
"Malaria",
"Lung Cancer"
],
"default_value": [],
"label": "Disease to Scan For",
"show_label": true,
"name": "checkboxgroup",
"css": {}
}
},
{
"id": 3,
"type": "tabs",
"props": {
"css": {},
"default_value": true
}
},
{
"id": 4,
"type": "tabitem",
"props": {
"label": "X-ray",
"css": {},
"default_value": true
}
},
{
"id": 5,
"type": "row",
"props": {
"type": "row",
"css": {},
"default_value": true
}
},
{
"id": 6,
"type": "image",
"props": {
"image_mode": "RGB",
"source": "upload",
"tool": "editor",
"show_label": true,
"name": "image",
"css": {}
}
},
{
"id": 7,
"type": "json",
"props": {
"default_value": "\"\"",
"show_label": true,
"name": "json",
"css": {}
}
},
{
"id": 8,
"type": "button",
"props": {
"default_value": "Run",
"name": "button",
"css": {}
}
},
{
"id": 9,
"type": "statustracker",
"props": {
"cover_container": true,
"name": "statustracker",
"css": {}
}
},
{
"id": 10,
"type": "tabitem",
"props": {
"label": "CT Scan",
"css": {},
"default_value": true
}
},
{
"id": 11,
"type": "row",
"props": {
"type": "row",
"css": {},
"default_value": true
}
},
{
"id": 12,
"type": "image",
"props": {
"image_mode": "RGB",
"source": "upload",
"tool": "editor",
"show_label": true,
"name": "image",
"css": {}
}
},
{
"id": 13,
"type": "json",
"props": {
"default_value": "\"\"",
"show_label": true,
"name": "json",
"css": {}
}
},
{
"id": 14,
"type": "button",
"props": {
"default_value": "Run",
"name": "button",
"css": {}
}
},
{
"id": 15,
"type": "statustracker",
"props": {
"cover_container": true,
"name": "statustracker",
"css": {}
}
},
{
"id": 16,
"type": "button",
"props": {
"default_value": "Upload Results",
"name": "button",
"css": {}
}
},
{
"id": 17,
"type": "statustracker",
"props": {
"cover_container": false,
"name": "statustracker",
"css": {}
}
}
],
"theme": "default",
"enable_queue": false,
"layout": {
"id": 0,
"children": [
{
"id": 1
},
{
"id": 2
},
{
"id": 3,
"children": [
{
"id": 4,
"children": [
{
"id": 5,
"children": [
{
"id": 6
},
{
"id": 7
}
]
},
{
"id": 8
},
{
"id": 9
}
]
},
{
"id": 10,
"children": [
{
"id": 11,
"children": [
{
"id": 12
},
{
"id": 13
}
]
},
{
"id": 14
},
{
"id": 15
}
]
}
]
},
{
"id": 16
},
{
"id": 17
}
]
},
"dependencies": [
{
"targets": [
8
],
"trigger": "click",
"inputs": [
2,
6
],
"outputs": [
7
],
"backend_fn": true,
"js": null,
"status_tracker": 9,
"queue": null
},
{
"targets": [
14
],
"trigger": "click",
"inputs": [
2,
12
],
"outputs": [
13
],
"backend_fn": true,
"js": null,
"status_tracker": 15,
"queue": null
},
{
"targets": [
16
],
"trigger": "click",
"inputs": [
13,
7
],
"outputs": [],
"backend_fn": true,
"js": null,
"status_tracker": 17,
"queue": null
}
]
}

View File

@ -0,0 +1,99 @@
{
"version": "3.0.6",
"mode": "blocks",
"dev_mode": true,
"components": [
{
"id": 1,
"type": "textbox",
"props": {
"lines": 5,
"max_lines": 20,
"value": "",
"label": "Input",
"show_label": true,
"name": "textbox",
"visible": true,
"style": {}
}
},
{
"id": 2,
"type": "textbox",
"props": {
"lines": 1,
"max_lines": 20,
"value": "",
"label": "Output-Interactive",
"show_label": true,
"name": "textbox",
"visible": true,
"style": {}
}
},
{
"id": 3,
"type": "textbox",
"props": {
"lines": 1,
"max_lines": 20,
"value": "Hello friends\nhello friends\n\nHello friends\n\n",
"label": "Output",
"show_label": true,
"interactive": false,
"name": "textbox",
"visible": true,
"style": {}
}
},
{
"id": 4,
"type": "button",
"props": {
"value": "Submit",
"variant": "secondary",
"name": "button",
"visible": true,
"style": {}
}
}
],
"theme": "default",
"css": null,
"enable_queue": false,
"layout": {
"id": 0,
"children": [
{
"id": 1
},
{
"id": 2
},
{
"id": 3
},
{
"id": 4
}
]
},
"dependencies": [
{
"targets": [
4
],
"trigger": "click",
"inputs": [
1
],
"outputs": [
2
],
"backend_fn": true,
"js": null,
"status_tracker": null,
"queue": null
}
]
}

View File

@ -10,7 +10,7 @@ Hello friends
with gr.Blocks() as demo:
txt = gr.Textbox(label="Input", lines=5)
txt_2 = gr.Textbox(label="Output")
txt_2 = gr.Textbox(label="Output-Interactive")
txt_3 = gr.Textbox(str, label="Output", interactive=False)
btn = gr.Button("Submit")
btn.click(lambda a: a, inputs=[txt], outputs=[txt_2])

View File

@ -0,0 +1,124 @@
{
"version": "3.0.6",
"mode": "blocks",
"dev_mode": true,
"components": [
{
"id": 1,
"type": "markdown",
"props": {
"value": "<p>Let's do some kinematics! Choose the speed and angle to see the trajectory.</p>\n",
"name": "markdown",
"visible": true,
"style": {}
}
},
{
"id": 2,
"type": "row",
"props": {
"type": "row",
"visible": true,
"style": {}
}
},
{
"id": 3,
"type": "slider",
"props": {
"minimum": 1,
"maximum": 30,
"step": 0.1,
"value": 25,
"label": "Speed",
"show_label": true,
"name": "slider",
"visible": true,
"style": {}
}
},
{
"id": 4,
"type": "slider",
"props": {
"minimum": 0,
"maximum": 90,
"step": 0.1,
"value": 45,
"label": "Angle",
"show_label": true,
"name": "slider",
"visible": true,
"style": {}
}
},
{
"id": 5,
"type": "plot",
"props": {
"show_label": true,
"name": "plot",
"visible": true,
"style": {}
}
},
{
"id": 6,
"type": "button",
"props": {
"value": "Run",
"variant": "secondary",
"name": "button",
"visible": true,
"style": {}
}
}
],
"theme": "default",
"css": null,
"enable_queue": false,
"layout": {
"id": 0,
"children": [
{
"id": 1
},
{
"id": 2,
"children": [
{
"id": 3
},
{
"id": 4
}
]
},
{
"id": 5
},
{
"id": 6
}
]
},
"dependencies": [
{
"targets": [
6
],
"trigger": "click",
"inputs": [
3,
4
],
"outputs": [
5
],
"backend_fn": true,
"js": null,
"status_tracker": null,
"queue": null
}
]
}

View File

@ -0,0 +1,325 @@
{
"mode": "blocks",
"components": [
{
"id": 1,
"type": "column",
"props": {
"type": "column",
"variant": "default",
"css": {},
"default_value": true
}
},
{
"id": 2,
"type": "textbox",
"props": {
"lines": 1,
"max_lines": 20,
"default_value": "",
"label": "Small Textbox",
"show_label": false,
"name": "textbox",
"css": {}
}
},
{
"id": 3,
"type": "textbox",
"props": {
"lines": 5,
"max_lines": 20,
"default_value": "",
"label": "Large Textbox",
"show_label": false,
"name": "textbox",
"css": {}
}
},
{
"id": 4,
"type": "number",
"props": {
"label": "Number",
"show_label": false,
"name": "number",
"css": {}
}
},
{
"id": 5,
"type": "checkbox",
"props": {
"default_value": false,
"label": "Checkbox",
"show_label": false,
"name": "checkbox",
"css": {}
}
},
{
"id": 6,
"type": "checkboxgroup",
"props": {
"choices": [
"One",
"Two",
"Three"
],
"default_value": [],
"label": "Checkbox Group",
"show_label": false,
"name": "checkboxgroup",
"css": {}
}
},
{
"id": 7,
"type": "radio",
"props": {
"choices": [
"One",
"Two",
"Three"
],
"default_value": "One",
"label": "Radio",
"show_label": false,
"name": "radio",
"css": {}
}
},
{
"id": 8,
"type": "dropdown",
"props": {
"choices": [
"One",
"Two",
"Three"
],
"default_value": "One",
"label": "Dropdown",
"show_label": false,
"name": "dropdown",
"css": {}
}
},
{
"id": 9,
"type": "slider",
"props": {
"minimum": 0,
"maximum": 100,
"step": 1,
"default_value": 0,
"label": "Slider",
"show_label": false,
"name": "slider",
"css": {}
}
},
{
"id": 10,
"type": "audio",
"props": {
"source": "upload",
"show_label": false,
"name": "audio",
"css": {}
}
},
{
"id": 11,
"type": "file",
"props": {
"file_count": "single",
"show_label": false,
"name": "file",
"css": {}
}
},
{
"id": 12,
"type": "video",
"props": {
"source": "upload",
"show_label": false,
"name": "video",
"css": {}
}
},
{
"id": 13,
"type": "image",
"props": {
"image_mode": "RGB",
"source": "upload",
"tool": "editor",
"show_label": false,
"name": "image",
"css": {}
}
},
{
"id": 14,
"type": "timeseries",
"props": {
"show_label": false,
"name": "timeseries",
"css": {}
}
},
{
"id": 15,
"type": "dataframe",
"props": {
"datatype": "str",
"row_count": 3,
"col_count": 3,
"default_value": [
[
"",
"",
""
],
[
"",
"",
""
],
[
"",
"",
""
]
],
"max_rows": 20,
"overflow_row_behaviour": "paginate",
"show_label": false,
"name": "dataframe",
"css": {}
}
},
{
"id": 16,
"type": "html",
"props": {
"default_value": "",
"show_label": false,
"name": "html",
"css": {}
}
},
{
"id": 17,
"type": "json",
"props": {
"default_value": "\"\"",
"show_label": false,
"name": "json",
"css": {}
}
},
{
"id": 18,
"type": "markdown",
"props": {
"default_value": "",
"name": "markdown",
"css": {}
}
},
{
"id": 19,
"type": "label",
"props": {
"show_label": false,
"name": "label",
"css": {}
}
},
{
"id": 20,
"type": "highlightedtext",
"props": {
"show_legend": false,
"default_value": "",
"show_label": false,
"name": "highlightedtext",
"css": {}
}
}
],
"theme": "default",
"enable_queue": false,
"layout": {
"id": 0,
"children": [
{
"id": 1,
"children": [
{
"id": 2
},
{
"id": 3
},
{
"id": 4
},
{
"id": 5
},
{
"id": 6
},
{
"id": 7
},
{
"id": 8
},
{
"id": 9
},
{
"id": 10
},
{
"id": 11
},
{
"id": 12
},
{
"id": 13
},
{
"id": 14
},
{
"id": 15
},
{
"id": 16
},
{
"id": 17
},
{
"id": 18
},
{
"id": 19
},
{
"id": 20
}
]
}
]
},
"dependencies": []
}

View File

@ -0,0 +1,58 @@
{
"mode": "blocks",
"components": [
{
"id": 1,
"type": "textbox",
"props": {
"lines": 1,
"max_lines": 20,
"default_value": "Frank",
"label": "Name",
"show_label": true,
"name": "textbox",
"css": {}
}
},
{
"id": 2,
"type": "textbox",
"props": {
"lines": 1,
"max_lines": 20,
"default_value": "",
"label": "Output",
"show_label": true,
"name": "textbox",
"css": {}
}
}
],
"theme": "default",
"enable_queue": false,
"layout": {
"id": 0,
"children": [
{
"id": 1
},
{
"id": 2
}
]
},
"dependencies": [
{
"targets": [],
"trigger": "load",
"inputs": [
1
],
"outputs": [
2
],
"status_tracker": null,
"queue": null
}
]
}

View File

@ -0,0 +1,115 @@
{
"version": "3.0.6",
"mode": "blocks",
"dev_mode": true,
"components": [
{
"id": 1,
"type": "variable",
"props": {
"value": 0,
"show_label": true,
"name": "variable",
"visible": true,
"style": {}
}
},
{
"id": 2,
"type": "number",
"props": {
"value": 0.0,
"show_label": true,
"name": "number",
"visible": true,
"style": {
"text_color": "blue",
"container_bg_color": "yellow"
}
}
},
{
"id": 3,
"type": "button",
"props": {
"value": "Next Square",
"variant": "secondary",
"name": "button",
"visible": true,
"elem_id": "btn",
"style": {
"rounded": false,
"bg_color": "purple"
}
}
},
{
"id": 4,
"type": "variable",
"props": {
"value": {
"a": "a"
},
"show_label": true,
"name": "variable",
"visible": true,
"style": {}
}
},
{
"id": 5,
"type": "json",
"props": {
"show_label": true,
"name": "json",
"visible": true,
"style": {}
}
}
],
"theme": "default",
"css": "#btn {color: red}",
"enable_queue": false,
"layout": {
"id": 0,
"children": [
{
"id": 1
},
{
"id": 2
},
{
"id": 3
},
{
"id": 4
},
{
"id": 5
}
]
},
"dependencies": [
{
"targets": [
3
],
"trigger": "click",
"inputs": [
1,
4
],
"outputs": [
1,
2,
4,
5
],
"backend_fn": true,
"js": null,
"status_tracker": null,
"queue": null
}
]
}

View File

@ -22,4 +22,4 @@ with demo:
btn.click(increase, [num, stats], [num, squared, stats, table])
if __name__ == "__main__":
demo.launch()
demo.launch()

View File

@ -1,5 +1,7 @@
{
"version": "3.0.6",
"mode": "blocks",
"dev_mode": true,
"components": [
{
"id": 1,
@ -7,29 +9,33 @@
"props": {
"value": "<h1>Detect Disease From Scan</h1>\n<p>With this model you can lorem ipsum</p>\n<ul>\n<li>ipsum 1</li>\n<li>ipsum 2</li>\n</ul>\n",
"name": "markdown",
"label": null,
"css": {},
"interactive": null
"visible": true,
"style": {}
}
},
{
"id": 2,
"type": "checkboxgroup",
"props": {
"choices": ["Covid", "Malaria", "Lung Cancer"],
"choices": [
"Covid",
"Malaria",
"Lung Cancer"
],
"value": [],
"name": "checkboxgroup",
"label": "Disease to Scan For",
"css": {},
"interactive": null
"show_label": true,
"name": "checkboxgroup",
"visible": true,
"style": {}
}
},
{
"id": 3,
"type": "tabs",
"props": {
"css": {},
"value": true
"visible": true,
"style": {}
}
},
{
@ -37,8 +43,8 @@
"type": "tabitem",
"props": {
"label": "X-ray",
"css": {},
"value": true
"visible": true,
"style": {}
}
},
{
@ -46,8 +52,8 @@
"type": "row",
"props": {
"type": "row",
"css": {},
"value": true
"visible": true,
"style": {}
}
},
{
@ -55,25 +61,23 @@
"type": "image",
"props": {
"image_mode": "RGB",
"shape": null,
"source": "upload",
"tool": "editor",
"value": null,
"streaming": false,
"show_label": true,
"name": "image",
"label": null,
"css": {},
"interactive": null
"visible": true,
"style": {}
}
},
{
"id": 7,
"type": "json",
"props": {
"value": "\"\"",
"show_label": true,
"name": "json",
"label": null,
"css": {},
"interactive": null
"visible": true,
"style": {}
}
},
{
@ -81,82 +85,110 @@
"type": "button",
"props": {
"value": "Run",
"variant": "secondary",
"name": "button",
"label": null,
"css": {},
"interactive": null
"visible": true,
"style": {}
}
},
{
"id": 9,
"type": "tabitem",
"type": "statustracker",
"props": {
"label": "CT Scan",
"css": {},
"value": true
"cover_container": true,
"name": "statustracker",
"visible": true,
"style": {}
}
},
{
"id": 10,
"type": "row",
"type": "tabitem",
"props": {
"type": "row",
"css": {},
"value": true
"label": "CT Scan",
"visible": true,
"style": {}
}
},
{
"id": 11,
"type": "image",
"type": "row",
"props": {
"image_mode": "RGB",
"shape": null,
"source": "upload",
"tool": "editor",
"value": null,
"name": "image",
"label": null,
"css": {},
"interactive": null
"type": "row",
"visible": true,
"style": {}
}
},
{
"id": 12,
"type": "json",
"type": "image",
"props": {
"value": "\"\"",
"name": "json",
"label": null,
"css": {},
"interactive": null
"image_mode": "RGB",
"source": "upload",
"tool": "editor",
"streaming": false,
"show_label": true,
"name": "image",
"visible": true,
"style": {}
}
},
{
"id": 13,
"type": "button",
"type": "json",
"props": {
"value": "Run",
"name": "button",
"label": null,
"css": {},
"interactive": null
"show_label": true,
"name": "json",
"visible": true,
"style": {}
}
},
{
"id": 14,
"type": "textbox",
"type": "button",
"props": {
"lines": 1,
"placeholder": null,
"value": "",
"name": "textbox",
"label": null,
"css": {},
"interactive": null
"value": "Run",
"variant": "secondary",
"name": "button",
"visible": true,
"style": {}
}
},
{
"id": 15,
"type": "statustracker",
"props": {
"cover_container": true,
"name": "statustracker",
"visible": true,
"style": {}
}
},
{
"id": 16,
"type": "button",
"props": {
"value": "Upload Results",
"variant": "secondary",
"name": "button",
"visible": true,
"style": {}
}
},
{
"id": 17,
"type": "statustracker",
"props": {
"cover_container": false,
"name": "statustracker",
"visible": true,
"style": {}
}
}
],
"theme": "default",
"css": null,
"enable_queue": false,
"layout": {
"id": 0,
"children": [
@ -185,49 +217,93 @@
},
{
"id": 8
},
{
"id": 9
}
]
},
{
"id": 9,
"id": 10,
"children": [
{
"id": 10,
"id": 11,
"children": [
{
"id": 11
"id": 12
},
{
"id": 12
"id": 13
}
]
},
{
"id": 13
"id": 14
},
{
"id": 15
}
]
}
]
},
{
"id": 14
"id": 16
},
{
"id": 17
}
]
},
"dependencies": [
{
"targets": [8],
"targets": [
8
],
"trigger": "click",
"inputs": [2, 6],
"outputs": [7],
"queue": false
"inputs": [
2,
6
],
"outputs": [
7
],
"backend_fn": true,
"js": null,
"status_tracker": 9,
"queue": null
},
{
"targets": [13],
"targets": [
14
],
"trigger": "click",
"inputs": [2, 11],
"outputs": [12],
"queue": false
"inputs": [
2,
12
],
"outputs": [
13
],
"backend_fn": true,
"js": null,
"status_tracker": 15,
"queue": null
},
{
"targets": [
16
],
"trigger": "click",
"inputs": [
13,
7
],
"outputs": [],
"backend_fn": true,
"js": null,
"status_tracker": 17,
"queue": null
}
]
}
}

View File

@ -12,7 +12,5 @@ with demo:
btn = gr.Button("Run")
btn.click(image_mod, text, text)
print(demo.get_config_file())
if __name__ == "__main__":
demo.launch()

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,310 @@
{
"mode": "blocks",
"components": [
{
"id": 7,
"type": "row",
"props": {
"type": "row",
"css": {},
"default_value": true
}
},
{
"id": 8,
"type": "column",
"props": {
"type": "column",
"variant": "panel",
"css": {},
"default_value": true
}
},
{
"id": 9,
"type": "column",
"props": {
"type": "column",
"variant": "default",
"css": {},
"default_value": true
}
},
{
"id": 0,
"type": "dropdown",
"props": {
"choices": [
"Matplotlib",
"Plotly",
"Bokeh"
],
"default_value": "Matplotlib",
"label": "Plot Type",
"show_label": true,
"name": "dropdown",
"css": {}
}
},
{
"id": 1,
"type": "slider",
"props": {
"minimum": 1,
"maximum": 4,
"step": 0.01,
"default_value": 3.2,
"label": "R",
"show_label": true,
"name": "slider",
"css": {}
}
},
{
"id": 2,
"type": "dropdown",
"props": {
"choices": [
"January",
"February",
"March",
"April",
"May"
],
"default_value": "January",
"label": "Month",
"show_label": true,
"name": "dropdown",
"css": {}
}
},
{
"id": 3,
"type": "checkboxgroup",
"props": {
"choices": [
"USA",
"Canada",
"Mexico",
"UK"
],
"default_value": [
"USA",
"Canada"
],
"label": "Countries",
"show_label": true,
"name": "checkboxgroup",
"css": {}
}
},
{
"id": 4,
"type": "checkbox",
"props": {
"default_value": false,
"label": "Social Distancing?",
"show_label": true,
"name": "checkbox",
"css": {}
}
},
{
"id": 10,
"type": "row",
"props": {
"type": "row",
"css": {},
"default_value": true
}
},
{
"id": 11,
"type": "button",
"props": {
"default_value": "Clear",
"name": "button",
"css": {}
}
},
{
"id": 12,
"type": "button",
"props": {
"default_value": "Submit",
"name": "button",
"css": {}
}
},
{
"id": 13,
"type": "column",
"props": {
"type": "column",
"variant": "panel",
"css": {},
"default_value": true
}
},
{
"id": 14,
"type": "statustracker",
"props": {
"cover_container": true,
"name": "statustracker",
"css": {}
}
},
{
"id": 5,
"type": "plot",
"props": {
"label": "output",
"show_label": true,
"interactive": false,
"name": "plot",
"css": {}
}
},
{
"id": 15,
"type": "row",
"props": {
"type": "row",
"css": {},
"default_value": true
}
},
{
"id": 16,
"type": "button",
"props": {
"default_value": "Flag",
"name": "button",
"css": {}
}
}
],
"theme": "default",
"enable_queue": false,
"layout": {
"id": 6,
"children": [
{
"id": 7,
"children": [
{
"id": 8,
"children": [
{
"id": 9,
"children": [
{
"id": 0
},
{
"id": 1
},
{
"id": 2
},
{
"id": 3
},
{
"id": 4
}
]
},
{
"id": 10,
"children": [
{
"id": 11
},
{
"id": 12
}
]
}
]
},
{
"id": 13,
"children": [
{
"id": 14
},
{
"id": 5
},
{
"id": 15,
"children": [
{
"id": 16
}
]
}
]
}
]
}
]
},
"dependencies": [
{
"targets": [
16
],
"trigger": "click",
"inputs": [
0,
1,
2,
3,
4,
5
],
"outputs": [],
"status_tracker": null,
"queue": null
},
{
"targets": [
12
],
"trigger": "click",
"inputs": [
0,
1,
2,
3,
4
],
"outputs": [
5
],
"status_tracker": 14,
"queue": null
},
{
"targets": [
11
],
"trigger": "click",
"inputs": [],
"outputs": [
0,
1,
2,
3,
4,
5,
9
],
"status_tracker": null,
"queue": null
}
]
}

4031
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

5
package.json Normal file
View File

@ -0,0 +1,5 @@
{
"devDependencies": {
"@playwright/test": "^1.21.1"
}
}

1352
pnpm-lock.yaml generated Normal file

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,44 @@
import { test, expect, Page } from "@playwright/test";
function mock_demo(page: Page, demo: string) {
return page.route("**/config", (route) => {
return route.fulfill({
headers: {
"Access-Control-Allow-Origin": "*"
},
path: `../../../demo/${demo}/config.json`
});
});
}
function mock_api(page: Page, body: Array<unknown>) {
return page.route("**/api/predict/", (route) => {
const id = JSON.parse(route.request().postData()!).fn_index;
return route.fulfill({
headers: {
"Access-Control-Allow-Origin": "*"
},
body: JSON.stringify({
data: body[id]
})
});
});
}
test("renders the correct elements", async ({ page }) => {
await mock_demo(page, "blocks_inputs");
await mock_api(page, [["hello world"]]);
await page.goto("http://localhost:3000");
const textbox = await page.locator("label:has-text('Input')");
const button = await page.locator("button");
await textbox.fill("hello world");
await Promise.all([button.click(), page.waitForResponse("**/api/predict/")]);
await expect(
await page.inputValue("label:has-text('Output-Interactive')")
).toEqual("hello world");
await expect(await page.inputValue("label:has-text('Input')")).toEqual(
"hello world"
);
});

View File

@ -0,0 +1,35 @@
import { test, expect, Page } from "@playwright/test";
function mock_demo(page: Page, demo: string) {
return page.route("**/config", (route) => {
return route.fulfill({
headers: {
"Access-Control-Allow-Origin": "*"
},
path: `../../../demo/${demo}/config.json`
});
});
}
function mock_api(page: Page, body: Array<unknown>) {
return page.route("**/api/predict/", (route) => {
const id = JSON.parse(route.request().postData()!).fn_index;
return route.fulfill({
headers: {
"Access-Control-Allow-Origin": "*"
},
body: JSON.stringify({
data: body[id]
})
});
});
}
test("renders the correct elements", async ({ page }) => {
await mock_demo(page, "blocks_kinematics");
await mock_api(page, [[25, 45]]);
await page.goto("http://localhost:3000");
const button = await page.locator("button");
await Promise.all([button.click(), page.waitForResponse("**/api/predict/")]);
});

View File

@ -0,0 +1,42 @@
import { test, expect, Page } from "@playwright/test";
function mock_demo(page: Page, demo: string) {
return page.route("**/config", (route) => {
return route.fulfill({
headers: {
"Access-Control-Allow-Origin": "*"
},
path: `../../../demo/${demo}/config.json`
});
});
}
function mock_api(page: Page, body: Array<unknown>) {
return page.route("**/api/predict/", (route) => {
const id = JSON.parse(route.request().postData()!).fn_index;
return route.fulfill({
headers: {
"Access-Control-Allow-Origin": "*"
},
body: JSON.stringify({
data: body[id]
})
});
});
}
test("renders the correct elements", async ({ page }) => {
await mock_demo(page, "blocks_page_load");
await mock_api(page, [["Welcome! This page has loaded for Frank"]]);
await page.goto("http://localhost:3000");
const textbox = await page.locator("label:has-text('Name')");
await textbox.fill("Frank");
await expect(await page.inputValue("label:has-text('Name')")).toEqual(
"Frank"
);
await expect(await page.inputValue("label:has-text('Output')")).toEqual(
"Welcome! This page has loaded for Frank"
);
});

View File

@ -27,17 +27,15 @@ function mock_api(page: Page, body: Array<unknown>) {
test("a component acts as both input and output", async ({ page }) => {
await mock_demo(page, "input-output");
await mock_api(page, [["world hello"]]);
await mock_api(page, [["tset"]]);
await page.goto("http://localhost:3000");
const textbox = await page.locator("label:has-text('Input-Output')");
const button = await page.locator("button");
await textbox.fill("hello world");
await textbox.fill("test");
await Promise.all([button.click(), page.waitForResponse("**/api/predict/")]);
await expect(await page.inputValue("label:has-text('Input-Output')")).toEqual(
"world hello"
"tset"
);
});