Merge pull request #904 from j9ac9k/take-screenshots
Take screenshots + Show Resolution
This commit is contained in:
commit
52fef555ee
@ -135,6 +135,8 @@ if __name__ == '__main__':
|
|||||||
lib = 'PyQt4'
|
lib = 'PyQt4'
|
||||||
elif '--pyqt5' in args:
|
elif '--pyqt5' in args:
|
||||||
lib = 'PyQt5'
|
lib = 'PyQt5'
|
||||||
|
elif '--pyside2' in args:
|
||||||
|
lib = 'PySide2'
|
||||||
else:
|
else:
|
||||||
lib = ''
|
lib = ''
|
||||||
|
|
||||||
|
@ -31,7 +31,6 @@ def init_viewbox():
|
|||||||
|
|
||||||
g = pg.GridItem()
|
g = pg.GridItem()
|
||||||
vb.addItem(g)
|
vb.addItem(g)
|
||||||
|
|
||||||
app.processEvents()
|
app.processEvents()
|
||||||
|
|
||||||
def test_ViewBox():
|
def test_ViewBox():
|
||||||
|
@ -191,6 +191,7 @@ def assertImageApproved(image, standardFile, message=None, **kwargs):
|
|||||||
if os.getenv('PYQTGRAPH_AUDIT_ALL') == '1':
|
if os.getenv('PYQTGRAPH_AUDIT_ALL') == '1':
|
||||||
raise Exception("Image test passed, but auditing due to PYQTGRAPH_AUDIT_ALL evnironment variable.")
|
raise Exception("Image test passed, but auditing due to PYQTGRAPH_AUDIT_ALL evnironment variable.")
|
||||||
except Exception:
|
except Exception:
|
||||||
|
|
||||||
if stdFileName in gitStatus(dataPath):
|
if stdFileName in gitStatus(dataPath):
|
||||||
print("\n\nWARNING: unit test failed against modified standard "
|
print("\n\nWARNING: unit test failed against modified standard "
|
||||||
"image %s.\nTo revert this file, run `cd %s; git checkout "
|
"image %s.\nTo revert this file, run `cd %s; git checkout "
|
||||||
@ -210,6 +211,9 @@ def assertImageApproved(image, standardFile, message=None, **kwargs):
|
|||||||
"PYQTGRAPH_AUDIT=1 to add this image." % stdFileName)
|
"PYQTGRAPH_AUDIT=1 to add this image." % stdFileName)
|
||||||
else:
|
else:
|
||||||
if os.getenv('TRAVIS') is not None:
|
if os.getenv('TRAVIS') is not None:
|
||||||
|
saveFailedTest(image, stdImage, standardFile, upload=True)
|
||||||
|
elif os.getenv('AZURE') is not None:
|
||||||
|
standardFile = r"artifacts/" + standardFile
|
||||||
saveFailedTest(image, stdImage, standardFile)
|
saveFailedTest(image, stdImage, standardFile)
|
||||||
print(graphstate)
|
print(graphstate)
|
||||||
raise
|
raise
|
||||||
@ -281,14 +285,13 @@ def assertImageMatch(im1, im2, minCorr=None, pxThreshold=50.,
|
|||||||
assert corr >= minCorr
|
assert corr >= minCorr
|
||||||
|
|
||||||
|
|
||||||
def saveFailedTest(data, expect, filename):
|
def saveFailedTest(data, expect, filename, upload=False):
|
||||||
"""Upload failed test images to web server to allow CI test debugging.
|
"""Upload failed test images to web server to allow CI test debugging.
|
||||||
"""
|
"""
|
||||||
commit = runSubprocess(['git', 'rev-parse', 'HEAD'])
|
commit = runSubprocess(['git', 'rev-parse', 'HEAD'])
|
||||||
name = filename.split('/')
|
name = filename.split(os.path.sep)
|
||||||
name.insert(-1, commit.strip())
|
name.insert(-1, commit.strip())
|
||||||
filename = '/'.join(name)
|
filename = os.path.sep.join(name)
|
||||||
host = 'data.pyqtgraph.org'
|
|
||||||
|
|
||||||
# concatenate data, expect, and diff into a single image
|
# concatenate data, expect, and diff into a single image
|
||||||
ds = data.shape
|
ds = data.shape
|
||||||
@ -306,15 +309,25 @@ def saveFailedTest(data, expect, filename):
|
|||||||
img[2:2+diff.shape[0], -diff.shape[1]-2:-2] = diff
|
img[2:2+diff.shape[0], -diff.shape[1]-2:-2] = diff
|
||||||
|
|
||||||
png = makePng(img)
|
png = makePng(img)
|
||||||
|
directory = os.path.dirname(filename)
|
||||||
|
if not os.path.isdir(directory):
|
||||||
|
os.makedirs(directory)
|
||||||
|
with open(filename + ".png", "wb") as png_file:
|
||||||
|
png_file.write(png)
|
||||||
|
print("\nImage comparison failed. Test result: %s %s Expected result: "
|
||||||
|
"%s %s" % (data.shape, data.dtype, expect.shape, expect.dtype))
|
||||||
|
if upload:
|
||||||
|
uploadFailedTest(filename, png)
|
||||||
|
|
||||||
|
def uploadFailedTest(filename, png):
|
||||||
|
host = 'data.pyqtgraph.org'
|
||||||
conn = httplib.HTTPConnection(host)
|
conn = httplib.HTTPConnection(host)
|
||||||
req = urllib.urlencode({'name': filename,
|
req = urllib.urlencode({'name': filename,
|
||||||
'data': base64.b64encode(png)})
|
'data': base64.b64encode(png)})
|
||||||
conn.request('POST', '/upload.py', req)
|
conn.request('POST', '/upload.py', req)
|
||||||
response = conn.getresponse().read()
|
response = conn.getresponse().read()
|
||||||
conn.close()
|
conn.close()
|
||||||
print("\nImage comparison failed. Test result: %s %s Expected result: "
|
|
||||||
"%s %s" % (data.shape, data.dtype, expect.shape, expect.dtype))
|
|
||||||
print("Uploaded to: \nhttp://%s/data/%s" % (host, filename))
|
print("Uploaded to: \nhttp://%s/data/%s" % (host, filename))
|
||||||
if not response.startswith(b'OK'):
|
if not response.startswith(b'OK'):
|
||||||
print("WARNING: Error uploading data to %s" % host)
|
print("WARNING: Error uploading data to %s" % host)
|
||||||
@ -495,7 +508,7 @@ def getTestDataRepo():
|
|||||||
if not os.path.isdir(parentPath):
|
if not os.path.isdir(parentPath):
|
||||||
os.makedirs(parentPath)
|
os.makedirs(parentPath)
|
||||||
|
|
||||||
if os.getenv('TRAVIS') is not None:
|
if os.getenv('TRAVIS') is not None or os.getenv('AZURE') is not None:
|
||||||
# Create a shallow clone of the test-data repository (to avoid
|
# Create a shallow clone of the test-data repository (to avoid
|
||||||
# downloading more data than is necessary)
|
# downloading more data than is necessary)
|
||||||
os.makedirs(dataPath)
|
os.makedirs(dataPath)
|
||||||
|
7
test.py
7
test.py
@ -15,10 +15,15 @@ elif '--pyqt4' in args:
|
|||||||
elif '--pyqt5' in args:
|
elif '--pyqt5' in args:
|
||||||
args.remove('--pyqt5')
|
args.remove('--pyqt5')
|
||||||
import PyQt5
|
import PyQt5
|
||||||
|
elif '--pyside2' in args:
|
||||||
|
args.remove('--pyside2')
|
||||||
|
import PySide2
|
||||||
|
|
||||||
import pyqtgraph as pg
|
import pyqtgraph as pg
|
||||||
pg.systemInfo()
|
pg.systemInfo()
|
||||||
|
qApp = pg.mkQApp()
|
||||||
|
desktop = qApp.desktop().screenGeometry()
|
||||||
|
print("\n\nDesktop Resolution: {} x {}\n\n".format(desktop.width(), desktop.height()))
|
||||||
pytest.main(args)
|
pytest.main(args)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user