Merge pull request #6568 from mezotaken/fix-tests
Tests fixes and additions
This commit is contained in:
commit
9bec415bab
2
.github/workflows/run_tests.yaml
vendored
2
.github/workflows/run_tests.yaml
vendored
|
@ -18,7 +18,7 @@ jobs:
|
||||||
cache-dependency-path: |
|
cache-dependency-path: |
|
||||||
**/requirements*txt
|
**/requirements*txt
|
||||||
- name: Run tests
|
- name: Run tests
|
||||||
run: python launch.py --tests basic_features --no-half --disable-opt-split-attention --use-cpu all --skip-torch-cuda-test
|
run: python launch.py --tests --no-half --disable-opt-split-attention --use-cpu all --skip-torch-cuda-test
|
||||||
- name: Upload main app stdout-stderr
|
- name: Upload main app stdout-stderr
|
||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v3
|
||||||
if: always()
|
if: always()
|
||||||
|
|
|
@ -1,29 +0,0 @@
|
||||||
import unittest
|
|
||||||
|
|
||||||
|
|
||||||
class TestExtrasWorking(unittest.TestCase):
|
|
||||||
def setUp(self):
|
|
||||||
self.url_img2img = "http://localhost:7860/sdapi/v1/extra-single-image"
|
|
||||||
self.simple_extras = {
|
|
||||||
"resize_mode": 0,
|
|
||||||
"show_extras_results": True,
|
|
||||||
"gfpgan_visibility": 0,
|
|
||||||
"codeformer_visibility": 0,
|
|
||||||
"codeformer_weight": 0,
|
|
||||||
"upscaling_resize": 2,
|
|
||||||
"upscaling_resize_w": 128,
|
|
||||||
"upscaling_resize_h": 128,
|
|
||||||
"upscaling_crop": True,
|
|
||||||
"upscaler_1": "None",
|
|
||||||
"upscaler_2": "None",
|
|
||||||
"extras_upscaler_2_visibility": 0,
|
|
||||||
"image": ""
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
class TestExtrasCorrectness(unittest.TestCase):
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
unittest.main()
|
|
|
@ -1,47 +0,0 @@
|
||||||
import unittest
|
|
||||||
import requests
|
|
||||||
|
|
||||||
|
|
||||||
class TestTxt2ImgWorking(unittest.TestCase):
|
|
||||||
def setUp(self):
|
|
||||||
self.url_txt2img = "http://localhost:7860/sdapi/v1/txt2img"
|
|
||||||
self.simple_txt2img = {
|
|
||||||
"enable_hr": False,
|
|
||||||
"denoising_strength": 0,
|
|
||||||
"firstphase_width": 0,
|
|
||||||
"firstphase_height": 0,
|
|
||||||
"prompt": "example prompt",
|
|
||||||
"styles": [],
|
|
||||||
"seed": -1,
|
|
||||||
"subseed": -1,
|
|
||||||
"subseed_strength": 0,
|
|
||||||
"seed_resize_from_h": -1,
|
|
||||||
"seed_resize_from_w": -1,
|
|
||||||
"batch_size": 1,
|
|
||||||
"n_iter": 1,
|
|
||||||
"steps": 3,
|
|
||||||
"cfg_scale": 7,
|
|
||||||
"width": 64,
|
|
||||||
"height": 64,
|
|
||||||
"restore_faces": False,
|
|
||||||
"tiling": False,
|
|
||||||
"negative_prompt": "",
|
|
||||||
"eta": 0,
|
|
||||||
"s_churn": 0,
|
|
||||||
"s_tmax": 0,
|
|
||||||
"s_tmin": 0,
|
|
||||||
"s_noise": 1,
|
|
||||||
"sampler_index": "Euler a"
|
|
||||||
}
|
|
||||||
|
|
||||||
def test_txt2img_with_restore_faces_performed(self):
|
|
||||||
self.simple_txt2img["restore_faces"] = True
|
|
||||||
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
|
||||||
|
|
||||||
|
|
||||||
class TestTxt2ImgCorrectness(unittest.TestCase):
|
|
||||||
pass
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
unittest.main()
|
|
54
test/basic_features/extras_test.py
Normal file
54
test/basic_features/extras_test.py
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
import unittest
|
||||||
|
import requests
|
||||||
|
from gradio.processing_utils import encode_pil_to_base64
|
||||||
|
from PIL import Image
|
||||||
|
|
||||||
|
class TestExtrasWorking(unittest.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
self.url_extras_single = "http://localhost:7860/sdapi/v1/extra-single-image"
|
||||||
|
self.extras_single = {
|
||||||
|
"resize_mode": 0,
|
||||||
|
"show_extras_results": True,
|
||||||
|
"gfpgan_visibility": 0,
|
||||||
|
"codeformer_visibility": 0,
|
||||||
|
"codeformer_weight": 0,
|
||||||
|
"upscaling_resize": 2,
|
||||||
|
"upscaling_resize_w": 128,
|
||||||
|
"upscaling_resize_h": 128,
|
||||||
|
"upscaling_crop": True,
|
||||||
|
"upscaler_1": "None",
|
||||||
|
"upscaler_2": "None",
|
||||||
|
"extras_upscaler_2_visibility": 0,
|
||||||
|
"image": encode_pil_to_base64(Image.open(r"test/test_files/img2img_basic.png"))
|
||||||
|
}
|
||||||
|
|
||||||
|
def test_simple_upscaling_performed(self):
|
||||||
|
self.extras_single["upscaler_1"] = "Lanczos"
|
||||||
|
self.assertEqual(requests.post(self.url_extras_single, json=self.extras_single).status_code, 200)
|
||||||
|
|
||||||
|
|
||||||
|
class TestPngInfoWorking(unittest.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
self.url_png_info = "http://localhost:7860/sdapi/v1/extra-single-image"
|
||||||
|
self.png_info = {
|
||||||
|
"image": encode_pil_to_base64(Image.open(r"test/test_files/img2img_basic.png"))
|
||||||
|
}
|
||||||
|
|
||||||
|
def test_png_info_performed(self):
|
||||||
|
self.assertEqual(requests.post(self.url_png_info, json=self.png_info).status_code, 200)
|
||||||
|
|
||||||
|
|
||||||
|
class TestInterrogateWorking(unittest.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
self.url_interrogate = "http://localhost:7860/sdapi/v1/extra-single-image"
|
||||||
|
self.interrogate = {
|
||||||
|
"image": encode_pil_to_base64(Image.open(r"test/test_files/img2img_basic.png")),
|
||||||
|
"model": "clip"
|
||||||
|
}
|
||||||
|
|
||||||
|
def test_interrogate_performed(self):
|
||||||
|
self.assertEqual(requests.post(self.url_interrogate, json=self.interrogate).status_code, 200)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
unittest.main()
|
|
@ -16,7 +16,7 @@ class TestImg2ImgWorking(unittest.TestCase):
|
||||||
"inpainting_fill": 0,
|
"inpainting_fill": 0,
|
||||||
"inpaint_full_res": False,
|
"inpaint_full_res": False,
|
||||||
"inpaint_full_res_padding": 0,
|
"inpaint_full_res_padding": 0,
|
||||||
"inpainting_mask_invert": 0,
|
"inpainting_mask_invert": False,
|
||||||
"prompt": "example prompt",
|
"prompt": "example prompt",
|
||||||
"styles": [],
|
"styles": [],
|
||||||
"seed": -1,
|
"seed": -1,
|
||||||
|
@ -50,6 +50,11 @@ class TestImg2ImgWorking(unittest.TestCase):
|
||||||
self.simple_img2img["mask"] = encode_pil_to_base64(Image.open(r"test/test_files/mask_basic.png"))
|
self.simple_img2img["mask"] = encode_pil_to_base64(Image.open(r"test/test_files/mask_basic.png"))
|
||||||
self.assertEqual(requests.post(self.url_img2img, json=self.simple_img2img).status_code, 200)
|
self.assertEqual(requests.post(self.url_img2img, json=self.simple_img2img).status_code, 200)
|
||||||
|
|
||||||
|
def test_inpainting_with_inverted_masked_performed(self):
|
||||||
|
self.simple_img2img["mask"] = encode_pil_to_base64(Image.open(r"test/test_files/mask_basic.png"))
|
||||||
|
self.simple_img2img["inpainting_mask_invert"] = True
|
||||||
|
self.assertEqual(requests.post(self.url_img2img, json=self.simple_img2img).status_code, 200)
|
||||||
|
|
||||||
def test_img2img_sd_upscale_performed(self):
|
def test_img2img_sd_upscale_performed(self):
|
||||||
self.simple_img2img["script_name"] = "sd upscale"
|
self.simple_img2img["script_name"] = "sd upscale"
|
||||||
self.simple_img2img["script_args"] = ["", 8, "Lanczos", 2.0]
|
self.simple_img2img["script_args"] = ["", 8, "Lanczos", 2.0]
|
||||||
|
|
|
@ -41,6 +41,9 @@ class TestTxt2ImgWorking(unittest.TestCase):
|
||||||
self.simple_txt2img["negative_prompt"] = "example negative prompt"
|
self.simple_txt2img["negative_prompt"] = "example negative prompt"
|
||||||
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
||||||
|
|
||||||
|
def test_txt2img_with_complex_prompt_performed(self):
|
||||||
|
self.simple_txt2img["prompt"] = "((emphasis)), (emphasis1:1.1), [to:1], [from::2], [from:to:0.3], [alt|alt1]"
|
||||||
|
|
||||||
def test_txt2img_not_square_image_performed(self):
|
def test_txt2img_not_square_image_performed(self):
|
||||||
self.simple_txt2img["height"] = 128
|
self.simple_txt2img["height"] = 128
|
||||||
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
||||||
|
@ -53,6 +56,10 @@ class TestTxt2ImgWorking(unittest.TestCase):
|
||||||
self.simple_txt2img["tiling"] = True
|
self.simple_txt2img["tiling"] = True
|
||||||
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
||||||
|
|
||||||
|
def test_txt2img_with_restore_faces_performed(self):
|
||||||
|
self.simple_txt2img["restore_faces"] = True
|
||||||
|
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
||||||
|
|
||||||
def test_txt2img_with_vanilla_sampler_performed(self):
|
def test_txt2img_with_vanilla_sampler_performed(self):
|
||||||
self.simple_txt2img["sampler_index"] = "PLMS"
|
self.simple_txt2img["sampler_index"] = "PLMS"
|
||||||
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
||||||
|
@ -63,6 +70,10 @@ class TestTxt2ImgWorking(unittest.TestCase):
|
||||||
self.simple_txt2img["n_iter"] = 2
|
self.simple_txt2img["n_iter"] = 2
|
||||||
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
||||||
|
|
||||||
|
def test_txt2img_batch_performed(self):
|
||||||
|
self.simple_txt2img["batch_size"] = 2
|
||||||
|
self.assertEqual(requests.post(self.url_txt2img, json=self.simple_txt2img).status_code, 200)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
|
|
@ -14,10 +14,25 @@ class UtilsTests(unittest.TestCase):
|
||||||
self.url_prompt_styles = "http://localhost:7860/sdapi/v1/prompt-styles"
|
self.url_prompt_styles = "http://localhost:7860/sdapi/v1/prompt-styles"
|
||||||
self.url_artist_categories = "http://localhost:7860/sdapi/v1/artist-categories"
|
self.url_artist_categories = "http://localhost:7860/sdapi/v1/artist-categories"
|
||||||
self.url_artists = "http://localhost:7860/sdapi/v1/artists"
|
self.url_artists = "http://localhost:7860/sdapi/v1/artists"
|
||||||
|
self.url_embeddings = "http://localhost:7860/sdapi/v1/embeddings"
|
||||||
|
|
||||||
def test_options_get(self):
|
def test_options_get(self):
|
||||||
self.assertEqual(requests.get(self.url_options).status_code, 200)
|
self.assertEqual(requests.get(self.url_options).status_code, 200)
|
||||||
|
|
||||||
|
def test_options_write(self):
|
||||||
|
response = requests.get(self.url_options)
|
||||||
|
self.assertEqual(response.status_code, 200)
|
||||||
|
|
||||||
|
pre_value = response.json()["send_seed"]
|
||||||
|
|
||||||
|
self.assertEqual(requests.post(self.url_options, json={"send_seed":not pre_value}).status_code, 200)
|
||||||
|
|
||||||
|
response = requests.get(self.url_options)
|
||||||
|
self.assertEqual(response.status_code, 200)
|
||||||
|
self.assertEqual(response.json()["send_seed"], not pre_value)
|
||||||
|
|
||||||
|
requests.post(self.url_options, json={"send_seed": pre_value})
|
||||||
|
|
||||||
def test_cmd_flags(self):
|
def test_cmd_flags(self):
|
||||||
self.assertEqual(requests.get(self.url_cmd_flags).status_code, 200)
|
self.assertEqual(requests.get(self.url_cmd_flags).status_code, 200)
|
||||||
|
|
||||||
|
@ -48,6 +63,8 @@ class UtilsTests(unittest.TestCase):
|
||||||
def test_artists(self):
|
def test_artists(self):
|
||||||
self.assertEqual(requests.get(self.url_artists).status_code, 200)
|
self.assertEqual(requests.get(self.url_artists).status_code, 200)
|
||||||
|
|
||||||
|
def test_embeddings(self):
|
||||||
|
self.assertEqual(requests.get(self.url_artists).status_code, 200)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
|
|
@ -15,7 +15,7 @@ def run_tests(proc, test_dir):
|
||||||
break
|
break
|
||||||
if proc.poll() is None:
|
if proc.poll() is None:
|
||||||
if test_dir is None:
|
if test_dir is None:
|
||||||
test_dir = ""
|
test_dir = "test"
|
||||||
suite = unittest.TestLoader().discover(test_dir, pattern="*_test.py", top_level_dir="test")
|
suite = unittest.TestLoader().discover(test_dir, pattern="*_test.py", top_level_dir="test")
|
||||||
result = unittest.TextTestRunner(verbosity=2).run(suite)
|
result = unittest.TextTestRunner(verbosity=2).run(suite)
|
||||||
return len(result.failures) + len(result.errors)
|
return len(result.failures) + len(result.errors)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user