2018-05-18 14:40:41 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
# Apache License, Version 2.0
|
|
|
|
|
|
|
|
import argparse
|
|
|
|
import os
|
|
|
|
import shlex
|
|
|
|
import shutil
|
|
|
|
import subprocess
|
|
|
|
import sys
|
|
|
|
|
2018-07-03 05:12:24 +00:00
|
|
|
|
2018-05-18 14:40:41 +00:00
|
|
|
def setup():
|
|
|
|
import bpy
|
|
|
|
|
2019-05-10 21:20:32 +00:00
|
|
|
for scene in bpy.data.scenes:
|
|
|
|
scene.render.engine = 'BLENDER_EEVEE'
|
|
|
|
|
2018-05-18 14:40:41 +00:00
|
|
|
# Enable Eevee features
|
|
|
|
scene = bpy.context.scene
|
|
|
|
eevee = scene.eevee
|
|
|
|
|
2018-05-26 09:54:25 +00:00
|
|
|
eevee.use_sss = True
|
|
|
|
eevee.use_ssr = True
|
|
|
|
eevee.use_ssr_refraction = True
|
|
|
|
eevee.use_gtao = True
|
2019-05-13 10:04:54 +00:00
|
|
|
eevee.use_dof = False
|
2018-05-26 09:54:25 +00:00
|
|
|
|
|
|
|
eevee.use_volumetric = True
|
|
|
|
eevee.use_volumetric_shadows = True
|
2018-05-18 14:40:41 +00:00
|
|
|
eevee.volumetric_tile_size = '2'
|
|
|
|
|
|
|
|
for mat in bpy.data.materials:
|
|
|
|
mat.use_screen_refraction = True
|
2019-05-05 16:31:49 +00:00
|
|
|
mat.use_sss_translucency = True
|
2018-05-18 14:40:41 +00:00
|
|
|
|
2018-07-03 05:12:24 +00:00
|
|
|
|
2018-05-18 14:40:41 +00:00
|
|
|
# When run from inside Blender, render and exit.
|
|
|
|
try:
|
|
|
|
import bpy
|
|
|
|
inside_blender = True
|
|
|
|
except ImportError:
|
|
|
|
inside_blender = False
|
|
|
|
|
|
|
|
if inside_blender:
|
|
|
|
try:
|
|
|
|
setup()
|
|
|
|
except Exception as e:
|
|
|
|
print(e)
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
|
2019-05-10 21:00:35 +00:00
|
|
|
def render_files(filepaths, output_filepaths):
|
2018-05-18 14:40:41 +00:00
|
|
|
command = [
|
|
|
|
BLENDER,
|
|
|
|
"--background",
|
|
|
|
"-noaudio",
|
|
|
|
"--factory-startup",
|
2019-05-10 21:00:35 +00:00
|
|
|
"--enable-autoexec"]
|
|
|
|
|
|
|
|
for filepath, output_filepath in zip(filepaths, output_filepaths):
|
|
|
|
frame_filepath = output_filepath + '0001.png'
|
|
|
|
if os.path.exists(frame_filepath):
|
|
|
|
os.remove(frame_filepath)
|
2018-05-18 14:40:41 +00:00
|
|
|
|
2019-05-10 21:00:35 +00:00
|
|
|
command.extend([
|
|
|
|
filepath,
|
|
|
|
"-E", "BLENDER_EEVEE",
|
|
|
|
"-P",
|
|
|
|
os.path.realpath(__file__),
|
|
|
|
"-o", output_filepath,
|
|
|
|
"-F", "PNG",
|
|
|
|
"-f", "1"])
|
|
|
|
|
|
|
|
error = None
|
2018-05-18 14:40:41 +00:00
|
|
|
try:
|
|
|
|
# Success
|
|
|
|
output = subprocess.check_output(command)
|
|
|
|
if VERBOSE:
|
|
|
|
print(" ".join(command))
|
|
|
|
print(output.decode("utf-8"))
|
|
|
|
except subprocess.CalledProcessError as e:
|
|
|
|
# Error
|
|
|
|
if VERBOSE:
|
|
|
|
print(" ".join(command))
|
|
|
|
print(e.output.decode("utf-8"))
|
2019-05-10 21:00:35 +00:00
|
|
|
error = "CRASH"
|
2018-05-18 14:40:41 +00:00
|
|
|
except BaseException as e:
|
|
|
|
# Crash
|
|
|
|
if VERBOSE:
|
|
|
|
print(" ".join(command))
|
2019-05-10 21:00:35 +00:00
|
|
|
print(e.decode("utf-8"))
|
|
|
|
error = "CRASH"
|
|
|
|
|
|
|
|
# Detect missing filepaths and consider those errors
|
|
|
|
errors = []
|
|
|
|
for output_filepath in output_filepaths:
|
|
|
|
frame_filepath = output_filepath + '0001.png'
|
|
|
|
if os.path.exists(frame_filepath):
|
|
|
|
shutil.copy(frame_filepath, output_filepath)
|
|
|
|
os.remove(frame_filepath)
|
|
|
|
errors.append(None)
|
|
|
|
else:
|
|
|
|
errors.append(error)
|
|
|
|
error = 'SKIPPED'
|
|
|
|
|
|
|
|
return errors
|
2018-05-18 14:40:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
def create_argparse():
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
parser.add_argument("-blender", nargs="+")
|
|
|
|
parser.add_argument("-testdir", nargs=1)
|
|
|
|
parser.add_argument("-outdir", nargs=1)
|
|
|
|
parser.add_argument("-idiff", nargs=1)
|
|
|
|
return parser
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
parser = create_argparse()
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
global BLENDER, VERBOSE
|
|
|
|
|
|
|
|
BLENDER = args.blender[0]
|
|
|
|
VERBOSE = os.environ.get("BLENDER_VERBOSE") is not None
|
|
|
|
|
|
|
|
test_dir = args.testdir[0]
|
|
|
|
idiff = args.idiff[0]
|
|
|
|
output_dir = args.outdir[0]
|
|
|
|
|
|
|
|
from modules import render_report
|
|
|
|
report = render_report.Report("Eevee Test Report", output_dir, idiff)
|
|
|
|
report.set_pixelated(True)
|
|
|
|
report.set_reference_dir("eevee_renders")
|
2018-05-18 15:52:46 +00:00
|
|
|
report.set_compare_engines('eevee', 'cycles')
|
2019-05-10 21:00:35 +00:00
|
|
|
ok = report.run(test_dir, render_files)
|
2018-05-18 14:40:41 +00:00
|
|
|
|
|
|
|
sys.exit(not ok)
|
|
|
|
|
|
|
|
|
|
|
|
if not inside_blender and __name__ == "__main__":
|
|
|
|
main()
|