mirror of
https://github.com/gradio-app/gradio.git
synced 2025-01-12 10:34:32 +08:00
228 lines
14 KiB
Python
228 lines
14 KiB
Python
import unittest
|
|
import gradio as gr
|
|
import numpy as np
|
|
import pandas as pd
|
|
|
|
class TestTextbox(unittest.TestCase):
|
|
def test_in_interface(self):
|
|
iface = gr.Interface(lambda x: x[-1], "textbox", gr.outputs.Textbox())
|
|
self.assertEqual(iface.process(["Hello"])[0], ["o"])
|
|
iface = gr.Interface(lambda x: x / 2, "number", gr.outputs.Textbox(type="number"))
|
|
self.assertEqual(iface.process([10])[0], [5])
|
|
|
|
|
|
class TestLabel(unittest.TestCase):
|
|
def test_as_component(self):
|
|
y = 'happy'
|
|
label_output = gr.outputs.Label()
|
|
label = label_output.postprocess(y)
|
|
self.assertDictEqual(label, {"label": "happy"})
|
|
|
|
y = {
|
|
3: 0.7,
|
|
1: 0.2,
|
|
0: 0.1
|
|
}
|
|
label_output = gr.outputs.Label()
|
|
label = label_output.postprocess(y)
|
|
self.assertDictEqual(label, {
|
|
"label": 3,
|
|
"confidences": [
|
|
{"label": 3, "confidence": 0.7},
|
|
{"label": 1, "confidence": 0.2},
|
|
{"label": 0, "confidence": 0.1},
|
|
]
|
|
})
|
|
|
|
def test_in_interface(self):
|
|
x_img = gr.test_data.BASE64_IMAGE
|
|
|
|
def rgb_distribution(img):
|
|
rgb_dist = np.mean(img, axis=(0, 1))
|
|
rgb_dist /= np.sum(rgb_dist)
|
|
rgb_dist = np.round(rgb_dist, decimals=2)
|
|
return {
|
|
"red": rgb_dist[0],
|
|
"green": rgb_dist[1],
|
|
"blue": rgb_dist[2],
|
|
}
|
|
|
|
iface = gr.Interface(rgb_distribution, "image", "label")
|
|
output = iface.process([x_img])[0][0]
|
|
self.assertDictEqual(output, {
|
|
'label': 'red',
|
|
'confidences': [
|
|
{'label': 'red', 'confidence': 0.44},
|
|
{'label': 'green', 'confidence': 0.28},
|
|
{'label': 'blue', 'confidence': 0.28}
|
|
]
|
|
})
|
|
|
|
class TestImage(unittest.TestCase):
|
|
def test_as_component(self):
|
|
y_img = gr.processing_utils.decode_base64_to_image(gr.test_data.BASE64_IMAGE)
|
|
image_output = gr.outputs.Image()
|
|
self.assertTrue(image_output.postprocess(y_img).startswith(""))
|
|
self.assertTrue(image_output.postprocess(np.array(y_img)).startswith(""))
|
|
|
|
def test_in_interface(self):
|
|
def generate_noise(width, height):
|
|
return np.random.randint(0, 256, (width, height, 3))
|
|
|
|
iface = gr.Interface(generate_noise, ["slider", "slider"], "image")
|
|
self.assertTrue(iface.process([10, 20])[0][0].startswith("data:image/png;base64"))
|
|
|
|
class TestKeyValues(unittest.TestCase):
|
|
def test_in_interface(self):
|
|
def letter_distribution(word):
|
|
dist = {}
|
|
for letter in word:
|
|
dist[letter] = dist.get(letter, 0) + 1
|
|
return dist
|
|
|
|
iface = gr.Interface(letter_distribution, "text", "key_values")
|
|
self.assertListEqual(iface.process(["alpaca"])[0][0], [
|
|
("a", 3), ("l", 1), ("p", 1), ("c", 1)])
|
|
|
|
class TestHighlightedText(unittest.TestCase):
|
|
def test_in_interface(self):
|
|
def highlight_vowels(sentence):
|
|
phrases, cur_phrase = [], ""
|
|
vowels, mode = "aeiou", None
|
|
for letter in sentence:
|
|
letter_mode = "vowel" if letter in vowels else "non"
|
|
if mode is None:
|
|
mode = letter_mode
|
|
elif mode != letter_mode:
|
|
phrases.append((cur_phrase, mode))
|
|
cur_phrase = ""
|
|
mode = letter_mode
|
|
cur_phrase += letter
|
|
phrases.append((cur_phrase, mode))
|
|
return phrases
|
|
|
|
iface = gr.Interface(highlight_vowels, "text", "highlight")
|
|
self.assertListEqual(iface.process(["Helloooo"])[0][0], [
|
|
("H", "non"), ("e", "vowel"), ("ll", "non"), ("oooo", "vowel")])
|
|
|
|
|
|
class TestAudio(unittest.TestCase):
|
|
def test_as_component(self):
|
|
y_audio = gr.processing_utils.decode_base64_to_file(gr.test_data.BASE64_AUDIO["data"])
|
|
audio_output = gr.outputs.Audio(type="file")
|
|
self.assertTrue(audio_output.postprocess(y_audio.name).startswith("data:audio/wav;base64,UklGRuI/AABXQVZFZm10IBAAA"))
|
|
|
|
def test_in_interface(self):
|
|
def generate_noise(duration):
|
|
return 48000, np.random.randint(-256, 256, (duration, 3)).astype(np.int16)
|
|
|
|
iface = gr.Interface(generate_noise, "slider", "audio")
|
|
self.assertTrue(iface.process([100])[0][0].startswith("data:audio/wav;base64"))
|
|
|
|
|
|
class TestJSON(unittest.TestCase):
|
|
def test_in_interface(self):
|
|
def get_avg_age_per_gender(data):
|
|
return {
|
|
"M": int(data[data["gender"] == "M"].mean()),
|
|
"F": int(data[data["gender"] == "F"].mean()),
|
|
"O": int(data[data["gender"] == "O"].mean()),
|
|
}
|
|
|
|
iface = gr.Interface(
|
|
get_avg_age_per_gender,
|
|
gr.inputs.Dataframe(headers=["gender", "age"]),
|
|
"json")
|
|
y_data = [
|
|
["M", 30],
|
|
["F", 20],
|
|
["M", 40],
|
|
["O", 20],
|
|
["F", 30],
|
|
]
|
|
self.assertDictEqual(iface.process([y_data])[0][0], {
|
|
"M": 35, "F": 25, "O": 20
|
|
})
|
|
|
|
|
|
class TestHTML(unittest.TestCase):
|
|
def test_in_interface(self):
|
|
def bold_text(text):
|
|
return "<strong>" + text + "</strong>"
|
|
|
|
iface = gr.Interface(bold_text, "text", "html")
|
|
self.assertEqual(iface.process(["test"])[0][0], "<strong>test</strong>")
|
|
|
|
|
|
class TestFile(unittest.TestCase):
|
|
def test_as_component(self):
|
|
def write_file(content):
|
|
with open("test.txt", "w") as f:
|
|
f.write(content)
|
|
return "test.txt"
|
|
|
|
iface = gr.Interface(write_file, "text", "file")
|
|
self.assertDictEqual(iface.process(["hello world"])[0][0], {
|
|
'name': 'test.txt', 'size': 11, 'data': 'aGVsbG8gd29ybGQ='
|
|
})
|
|
|
|
|
|
class TestDataframe(unittest.TestCase):
|
|
def test_as_component(self):
|
|
dataframe_output = gr.outputs.Dataframe()
|
|
output = dataframe_output.postprocess(np.zeros((2,2)))
|
|
self.assertDictEqual(output, {"data": [[0,0],[0,0]]})
|
|
output = dataframe_output.postprocess([[1,3,5]])
|
|
self.assertDictEqual(output, {"data": [[1, 3, 5]]})
|
|
output = dataframe_output.postprocess(pd.DataFrame(
|
|
[[2, True], [3, True], [4, False]], columns=["num", "prime"]))
|
|
self.assertDictEqual(output,
|
|
{"headers": ["num", "prime"], "data": [[2, True], [3, True], [4, False]]})
|
|
|
|
|
|
def test_in_interface(self):
|
|
def check_odd(array):
|
|
return array % 2 == 0
|
|
iface = gr.Interface(check_odd, "numpy", "numpy")
|
|
self.assertEqual(
|
|
iface.process([[2, 3, 4]])[0][0],
|
|
{"data": [[True, False, True]]})
|
|
|
|
|
|
class TestCarousel(unittest.TestCase):
|
|
def test_as_component(self):
|
|
carousel_output = gr.outputs.Carousel(["text", "image"], label="Disease")
|
|
|
|
output = carousel_output.postprocess([["Hello World", "test/test_files/bus.png"],
|
|
["Bye World", "test/test_files/bus.png"]])
|
|
self.assertEqual(output, [['Hello World', gr.test_data.BASE64_IMAGE],
|
|
['Bye World', gr.test_data.BASE64_IMAGE]])
|
|
|
|
def test_in_interface(self):
|
|
carousel_output = gr.outputs.Carousel(["text", "image"], label="Disease")
|
|
def report(img):
|
|
results = []
|
|
for i, mode in enumerate(["Red", "Green", "Blue"]):
|
|
color_filter = np.array([0, 0, 0])
|
|
color_filter[i] = 1
|
|
results.append([mode, img * color_filter])
|
|
return results
|
|
iface = gr.Interface(report, gr.inputs.Image(type="numpy"), carousel_output)
|
|
self.assertEqual(
|
|
iface.process([gr.test_data.BASE64_IMAGE])[0], [[['Red',
|
|
''],
|
|
['Green',
|
|
''],
|
|
['Blue',
|
|
'']]])
|
|
|
|
|
|
class TestNames(unittest.TestCase):
|
|
def test_no_duplicate_uncased_names(self): # this ensures that get_input_instance() works correctly when instantiating from components
|
|
subclasses = gr.outputs.OutputComponent.__subclasses__()
|
|
unique_subclasses_uncased = set([s.__name__.lower() for s in subclasses])
|
|
self.assertEqual(len(subclasses), len(unique_subclasses_uncased))
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|