2022-01-26 13:44:41 +08:00
|
|
|
import os
|
2021-11-02 00:40:51 +08:00
|
|
|
import tempfile
|
|
|
|
import unittest
|
2022-01-26 13:44:41 +08:00
|
|
|
from unittest.mock import MagicMock
|
|
|
|
|
|
|
|
import huggingface_hub
|
2021-11-02 00:40:51 +08:00
|
|
|
|
2022-01-21 21:44:12 +08:00
|
|
|
import gradio as gr
|
|
|
|
from gradio import flagging
|
|
|
|
|
2022-08-26 04:23:28 +08:00
|
|
|
os.environ["GRADIO_ANALYTICS_ENABLED"] = "False"
|
|
|
|
|
2022-03-26 02:14:42 +08:00
|
|
|
|
2022-03-26 02:12:45 +08:00
|
|
|
class TestDefaultFlagging(unittest.TestCase):
|
|
|
|
def test_default_flagging_callback(self):
|
|
|
|
with tempfile.TemporaryDirectory() as tmpdirname:
|
|
|
|
io = gr.Interface(lambda x: x, "text", "text", flagging_dir=tmpdirname)
|
|
|
|
io.launch(prevent_thread_lock=True)
|
|
|
|
row_count = io.flagging_callback.flag(["test", "test"])
|
|
|
|
self.assertEqual(row_count, 1) # 2 rows written including header
|
|
|
|
row_count = io.flagging_callback.flag(["test", "test"])
|
|
|
|
self.assertEqual(row_count, 2) # 3 rows written including header
|
|
|
|
io.close()
|
2021-11-02 00:40:51 +08:00
|
|
|
|
2022-01-24 12:54:48 +08:00
|
|
|
|
2022-03-26 02:12:45 +08:00
|
|
|
class TestSimpleFlagging(unittest.TestCase):
|
|
|
|
def test_simple_csv_flagging_callback(self):
|
|
|
|
with tempfile.TemporaryDirectory() as tmpdirname:
|
|
|
|
io = gr.Interface(
|
|
|
|
lambda x: x,
|
|
|
|
"text",
|
|
|
|
"text",
|
|
|
|
flagging_dir=tmpdirname,
|
|
|
|
flagging_callback=flagging.SimpleCSVLogger(),
|
|
|
|
)
|
|
|
|
io.launch(prevent_thread_lock=True)
|
|
|
|
row_count = io.flagging_callback.flag(["test", "test"])
|
|
|
|
self.assertEqual(row_count, 0) # no header in SimpleCSVLogger
|
|
|
|
row_count = io.flagging_callback.flag(["test", "test"])
|
|
|
|
self.assertEqual(row_count, 1) # no header in SimpleCSVLogger
|
|
|
|
io.close()
|
2021-11-02 00:40:51 +08:00
|
|
|
|
2022-02-09 02:56:13 +08:00
|
|
|
|
2022-03-26 02:12:45 +08:00
|
|
|
class TestHuggingFaceDatasetSaver(unittest.TestCase):
|
|
|
|
def test_saver_setup(self):
|
|
|
|
huggingface_hub.create_repo = MagicMock()
|
|
|
|
huggingface_hub.Repository = MagicMock()
|
|
|
|
flagger = flagging.HuggingFaceDatasetSaver("test", "test")
|
|
|
|
with tempfile.TemporaryDirectory() as tmpdirname:
|
|
|
|
flagger.setup([gr.Audio, gr.Textbox], tmpdirname)
|
|
|
|
huggingface_hub.create_repo.assert_called_once()
|
2022-02-09 02:56:13 +08:00
|
|
|
|
2022-03-26 02:12:45 +08:00
|
|
|
def test_saver_flag(self):
|
|
|
|
huggingface_hub.create_repo = MagicMock()
|
|
|
|
huggingface_hub.Repository = MagicMock()
|
|
|
|
with tempfile.TemporaryDirectory() as tmpdirname:
|
|
|
|
io = gr.Interface(
|
|
|
|
lambda x: x,
|
|
|
|
"text",
|
|
|
|
"text",
|
|
|
|
flagging_dir=tmpdirname,
|
|
|
|
flagging_callback=flagging.HuggingFaceDatasetSaver("test", "test"),
|
|
|
|
)
|
|
|
|
os.mkdir(os.path.join(tmpdirname, "test"))
|
|
|
|
io.launch(prevent_thread_lock=True)
|
|
|
|
row_count = io.flagging_callback.flag(["test", "test"])
|
|
|
|
self.assertEqual(row_count, 1) # 2 rows written including header
|
|
|
|
row_count = io.flagging_callback.flag(["test", "test"])
|
|
|
|
self.assertEqual(row_count, 2) # 3 rows written including header
|
2022-02-09 02:56:13 +08:00
|
|
|
|
|
|
|
|
2022-08-24 07:01:37 +08:00
|
|
|
class TestHuggingFaceDatasetJSONSaver(unittest.TestCase):
|
|
|
|
def test_saver_setup(self):
|
|
|
|
huggingface_hub.create_repo = MagicMock()
|
|
|
|
huggingface_hub.Repository = MagicMock()
|
|
|
|
flagger = flagging.HuggingFaceDatasetJSONSaver("test", "test")
|
|
|
|
with tempfile.TemporaryDirectory() as tmpdirname:
|
|
|
|
flagger.setup([gr.Audio, gr.Textbox], tmpdirname)
|
|
|
|
huggingface_hub.create_repo.assert_called_once()
|
|
|
|
|
|
|
|
def test_saver_flag(self):
|
|
|
|
huggingface_hub.create_repo = MagicMock()
|
|
|
|
huggingface_hub.Repository = MagicMock()
|
|
|
|
with tempfile.TemporaryDirectory() as tmpdirname:
|
|
|
|
io = gr.Interface(
|
|
|
|
lambda x: x,
|
|
|
|
"text",
|
|
|
|
"text",
|
|
|
|
flagging_dir=tmpdirname,
|
|
|
|
flagging_callback=flagging.HuggingFaceDatasetJSONSaver("test", "test"),
|
|
|
|
)
|
|
|
|
test_dir = os.path.join(tmpdirname, "test")
|
|
|
|
os.mkdir(test_dir)
|
|
|
|
io.launch(prevent_thread_lock=True)
|
|
|
|
row_unique_name = io.flagging_callback.flag(["test", "test"])
|
|
|
|
# Test existence of metadata.jsonl file for that example
|
|
|
|
self.assertEqual(
|
|
|
|
os.path.isfile(
|
|
|
|
os.path.join(
|
|
|
|
os.path.join(test_dir, row_unique_name), "metadata.jsonl"
|
|
|
|
)
|
|
|
|
),
|
|
|
|
True,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2022-02-15 18:14:47 +08:00
|
|
|
class TestDisableFlagging(unittest.TestCase):
|
|
|
|
def test_flagging_no_permission_error_with_flagging_disabled(self):
|
|
|
|
with tempfile.TemporaryDirectory() as tmpdirname:
|
|
|
|
os.chmod(tmpdirname, 0o444) # Make directory read-only
|
2022-02-16 08:32:42 +08:00
|
|
|
nonwritable_path = os.path.join(tmpdirname, "flagging_dir")
|
|
|
|
|
2022-02-15 18:14:47 +08:00
|
|
|
io = gr.Interface(
|
|
|
|
lambda x: x,
|
|
|
|
"text",
|
|
|
|
"text",
|
|
|
|
allow_flagging="never",
|
2022-02-16 08:32:42 +08:00
|
|
|
flagging_dir=nonwritable_path,
|
2022-02-15 18:14:47 +08:00
|
|
|
)
|
|
|
|
try:
|
|
|
|
io.launch(prevent_thread_lock=True)
|
|
|
|
except PermissionError:
|
|
|
|
self.fail("launch() raised a PermissionError unexpectedly")
|
2022-02-16 08:32:42 +08:00
|
|
|
|
2022-02-15 18:14:47 +08:00
|
|
|
io.close()
|
|
|
|
|
|
|
|
|
2022-01-21 21:44:12 +08:00
|
|
|
if __name__ == "__main__":
|
2021-11-02 00:40:51 +08:00
|
|
|
unittest.main()
|