We support pyside2 don't we?
This commit is contained in:
parent
f2426e9dd2
commit
2df71abfec
@ -12,8 +12,8 @@ jobs:
|
|||||||
matrix:
|
matrix:
|
||||||
Python27-Qt4:
|
Python27-Qt4:
|
||||||
python.version: '2.7'
|
python.version: '2.7'
|
||||||
install.method: "conda"
|
|
||||||
qt.bindings: "pyqt=4"
|
qt.bindings: "pyqt=4"
|
||||||
|
install.method: "conda"
|
||||||
Python27-PySide:
|
Python27-PySide:
|
||||||
python.version: '2.7'
|
python.version: '2.7'
|
||||||
qt.bindings: "pyside"
|
qt.bindings: "pyside"
|
||||||
@ -26,158 +26,145 @@ jobs:
|
|||||||
python.version: "3.7"
|
python.version: "3.7"
|
||||||
qt.bindings: "pyside2"
|
qt.bindings: "pyside2"
|
||||||
install.method: "conda"
|
install.method: "conda"
|
||||||
Python35-PyQt-5.12:
|
Python37-PyQt-5.12:
|
||||||
python.version: '3.5'
|
python.version: '3.7'
|
||||||
qt.bindings: "PyQt5"
|
qt.bindings: "PyQt5"
|
||||||
install.method: "pip"
|
install.method: "pip"
|
||||||
Python35-PySide2-5.12:
|
Python37-PySide2-5.12:
|
||||||
python.version: "3.5"
|
python.version: "3.7"
|
||||||
qt.bindings: "PySide2"
|
qt.bindings: "PySide2"
|
||||||
install.method: "pip"
|
install.method: "pip"
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- powershell: Write-Host "##vso[task.prependpath]$env:CONDA\Scripts"
|
- task: ScreenResolutionUtility@1
|
||||||
displayName: 'Windows - Add conda to PATH'
|
inputs:
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), eq(variables['agent.os'], 'Windows_NT' ))
|
displaySettings: 'specific'
|
||||||
|
width: '1920'
|
||||||
|
height: '1080'
|
||||||
|
condition: eq(variables['agent.os'], 'Windows_NT' )
|
||||||
|
|
||||||
|
- task: UsePythonVersion@0
|
||||||
|
inputs:
|
||||||
|
versionSpec: $(python.version)
|
||||||
|
condition: eq(variables['install.method'], 'pip')
|
||||||
|
|
||||||
- bash: |
|
- bash: |
|
||||||
echo "##vso[task.prependpath]$CONDA/bin"
|
if [ $(agent.os) == 'Linux' ]
|
||||||
sudo chown -R $USER $CONDA
|
then
|
||||||
displayName: 'MacOS - Add conda to PATH'
|
echo '##vso[task.prependpath]/usr/share/miniconda/bin'
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), eq(variables['agent.os'], 'Darwin' ))
|
elif [ $(agent.os) == 'Darwin' ]
|
||||||
|
then
|
||||||
|
echo '##vso[task.prependpath]$CONDA/bin'
|
||||||
|
sudo install -d -m 0777 /usr/local/miniconda/envs
|
||||||
|
elif [ $(agent.os) == 'Windows_NT' ]
|
||||||
|
then
|
||||||
|
echo "##vso[task.prependpath]$env:CONDA\Scripts"
|
||||||
|
else
|
||||||
|
echo 'Just what OS are you using?'
|
||||||
|
fi
|
||||||
|
displayName: 'Add Conda to $PATH'
|
||||||
|
condition: eq(variables['install.method'], 'conda' )
|
||||||
|
|
||||||
|
- task: CondaEnvironment@0
|
||||||
|
displayName: 'Create Conda Environment'
|
||||||
|
condition: eq(variables['install.method'], 'conda')
|
||||||
|
inputs:
|
||||||
|
environmentName: 'test-environment-$(python.version)'
|
||||||
|
packageSpecs: 'python=$(python.version)'
|
||||||
|
|
||||||
- bash: |
|
- bash: |
|
||||||
brew update && brew install azure-cli
|
if [ $(install.method) == "conda" ]
|
||||||
brew update && brew install python3 && brew upgrade python3
|
then
|
||||||
brew link --overwrite python3
|
source activate test-environment-$(python.version)
|
||||||
displayName: "MacOS - Intall Python3"
|
conda install -c conda-forge $(qt.bindings) numpy scipy pyopengl pytest flake8 six coverage --yes
|
||||||
condition: and(eq(variables['install.method'], 'pip' ), eq(variables['agent.os'], 'Darwin' ))
|
else
|
||||||
|
pip install $(qt.bindings) numpy scipy pyopengl pytest flake8 six coverage
|
||||||
|
fi
|
||||||
|
pip install pytest-xdist pytest-cov pytest-faulthandler
|
||||||
|
displayName: "Install Dependencies"
|
||||||
|
|
||||||
- bash: |
|
- bash: |
|
||||||
echo "##vso[task.prependpath]/usr/share/miniconda/bin"
|
if [ $(install.method) == "conda" ]
|
||||||
displayName: 'Linux - Add conda to PATH'
|
then
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), eq(variables['agent.os'], 'Linux' ))
|
source activate test-environment-$(python.version)
|
||||||
|
fi
|
||||||
|
|
||||||
|
pip install setuptools wheel
|
||||||
|
python setup.py bdist_wheel
|
||||||
|
pip install dist/*.whl
|
||||||
|
displayName: 'Build Wheel and Install'
|
||||||
|
|
||||||
|
- task: CopyFiles@2
|
||||||
|
inputs:
|
||||||
|
contents: 'dist/**'
|
||||||
|
targetFolder: $(Build.ArtifactStagingDirectory)
|
||||||
|
cleanTargetFolder: true # Optional
|
||||||
|
displayName: "Copy Distributions To Artifacts"
|
||||||
|
|
||||||
|
- task: PublishBuildArtifacts@1
|
||||||
|
displayName: 'Publish Distributions'
|
||||||
|
condition: always()
|
||||||
|
inputs:
|
||||||
|
pathtoPublish: $(Build.ArtifactStagingDirectory)/dist
|
||||||
|
artifactName: Distributions
|
||||||
|
|
||||||
- bash: |
|
- bash: |
|
||||||
# Install & Start Windows Manager for Linux
|
sudo apt-get install -y libxkbcommon-x11-0 # herbstluftwm
|
||||||
sudo apt-get install -y xvfb libxkbcommon-x11-0 # herbstluftwm
|
if [ $(install.method) == "conda" ]
|
||||||
displayName: 'Linux - Prepare OS'
|
then
|
||||||
|
source activate test-environment-$(python.version)
|
||||||
|
fi
|
||||||
|
pip install pytest-xvfb
|
||||||
|
displayName: "Linux Virtual Display Setup"
|
||||||
condition: eq(variables['agent.os'], 'Linux' )
|
condition: eq(variables['agent.os'], 'Linux' )
|
||||||
|
|
||||||
- bash: |
|
- bash: |
|
||||||
source $HOME/miniconda/etc/profile.d/conda.sh
|
if [ $(install.method) == "conda" ]
|
||||||
hash -r
|
then
|
||||||
conda config --set always_yes yes --set auto_update_conda no
|
source activate test-environment-$(python.version)
|
||||||
conda config --add channels conda-forge
|
fi
|
||||||
conda create -n test_env --quiet python=$(python.version)
|
echo python location: `which python`
|
||||||
displayName: 'Conda Setup Test Environment'
|
|
||||||
condition: eq(variables['install.method'], 'conda' )
|
|
||||||
|
|
||||||
- script: |
|
|
||||||
call activate test_env
|
|
||||||
conda install --quiet $(qt.bindings)
|
|
||||||
conda install --quiet numpy scipy pyopengl pytest flake8 six coverage
|
|
||||||
pip install pytest-azurepipelines pytest-xdist pytest-cov
|
|
||||||
displayName: Conda Install Dependencies - Windows
|
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), eq(variables['agent.os'], 'Windows_NT' ))
|
|
||||||
|
|
||||||
- bash: |
|
|
||||||
source activate test_env
|
|
||||||
conda install --quiet $(qt.bindings)
|
|
||||||
conda install --quiet numpy scipy pyopengl pytest flake8 six coverage
|
|
||||||
pip install pytest-azurepipelines pytest-xdist pytest-cov pytest-xvfb
|
|
||||||
displayName: Conda Install Dependencies - MacOS+Linux
|
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), ne(variables['agent.os'], 'Windows_NT' ))
|
|
||||||
|
|
||||||
- bash: |
|
|
||||||
pip3 install setuptools wheel
|
|
||||||
pip3 install $(qt.bindings)
|
|
||||||
pip3 install numpy scipy pyopengl pytest flake8 six coverage
|
|
||||||
pip3 install pytest-azurepipelines pytest-xdist pytest-cov pytest-xvfb
|
|
||||||
displayName: "Pip - Install Dependencies"
|
|
||||||
condition: eq(variables['install.method'], 'pip' )
|
|
||||||
|
|
||||||
- bash: |
|
|
||||||
source activate test_env
|
|
||||||
echo python location: `which python3`
|
|
||||||
echo python version: `python3 --version`
|
|
||||||
echo pytest location: `which pytest`
|
|
||||||
echo installed packages
|
|
||||||
conda list
|
|
||||||
echo pyqtgraph system info
|
|
||||||
python -c "import pyqtgraph as pg; pg.systemInfo()"
|
|
||||||
displayName: 'Debug - Conda/MacOS+Linux'
|
|
||||||
continueOnError: false
|
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), ne(variables['agent.os'], 'Windows_NT' ))
|
|
||||||
|
|
||||||
- script: |
|
|
||||||
call activate test_env
|
|
||||||
echo python location
|
|
||||||
where python
|
|
||||||
echo python version
|
|
||||||
python --version
|
|
||||||
echo pytest location
|
|
||||||
where pytest
|
|
||||||
echo installed packages
|
|
||||||
conda list
|
|
||||||
echo pyqtgraph system info
|
|
||||||
python -c "import pyqtgraph as pg; pg.systemInfo()"
|
|
||||||
displayName: 'Debug - Conda/Windows'
|
|
||||||
continueOnError: false
|
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), eq(variables['agent.os'], 'Windows_NT' ))
|
|
||||||
|
|
||||||
- bash: |
|
|
||||||
echo python location: `which python3`
|
|
||||||
echo python version: `python3 --version`
|
|
||||||
echo pytest location: `which pytest`
|
|
||||||
echo installed packages
|
|
||||||
pip3 list
|
|
||||||
echo pyqtgraph system info
|
|
||||||
python3 -c "import pyqtgraph as pg; pg.systemInfo()"
|
|
||||||
displayName: 'Debug - System/MacOS+Linux'
|
|
||||||
continueOnError: false
|
|
||||||
condition: and(eq(variables['install.method'], 'pip' ), ne(variables['agent.os'], 'Windows_NT' ))
|
|
||||||
|
|
||||||
- bash: |
|
|
||||||
echo python location: `where python`
|
|
||||||
echo python version: `python --version`
|
echo python version: `python --version`
|
||||||
echo pytest location: `where pytest`
|
echo pytest location: `which pytest`
|
||||||
echo installed packages
|
echo installed packages
|
||||||
python -m pip list
|
pip list
|
||||||
echo pyqtgraph system info
|
echo pyqtgraph system info
|
||||||
python -c "import pyqtgraph as pg; pg.systemInfo()"
|
python -c "import pyqtgraph as pg; pg.systemInfo()"
|
||||||
displayName: 'Debug - System/Windows'
|
displayName: 'Debug Info'
|
||||||
continueOnError: false
|
continueOnError: false
|
||||||
condition: and(eq(variables['install.method'], 'pip' ), eq(variables['agent.os'], 'Windows_NT' ))
|
|
||||||
|
|
||||||
- bash: python3 -m pytest --cov pyqtgraph -sv --test-run-title="Tests for $(Agent.OS) - Python $(python.version) - Install Method $(install.method)- Bindings $(qt.bindings)" --napoleon-docstrings
|
|
||||||
displayName: 'Tests - Run - Pip/MacOS+Linux'
|
|
||||||
continueOnError: false
|
|
||||||
env:
|
|
||||||
DISPLAY: :99.0
|
|
||||||
condition: and(eq(variables['install.method'], 'pip' ), ne(variables['agent.os'], 'Windows_NT' ))
|
|
||||||
|
|
||||||
- bash: python -m pytest --cov pyqtgraph -sv --test-run-title="Tests for $(Agent.OS) - Python $(python.version) - Install Method $(install.method)- Bindings $(qt.bindings)" --napoleon-docstrings
|
|
||||||
displayName: 'Tests - Run - Pip/Windows'
|
|
||||||
continueOnError: false
|
|
||||||
env:
|
|
||||||
DISPLAY: :99.0
|
|
||||||
condition: and(eq(variables['install.method'], 'pip' ), eq(variables['agent.os'], 'Windows_NT' ))
|
|
||||||
|
|
||||||
- bash: |
|
- bash: |
|
||||||
source activate test_env
|
if [ $(install.method) == "conda" ]
|
||||||
pytest --cov pyqtgraph -sv --test-run-title="Tests for $(Agent.OS) - Python $(python.version) - Install Method $(install.method)- Bindings $(qt.bindings)" --napoleon-docstrings
|
then
|
||||||
displayName: 'Tests - Run - Conda/MacOS+Linux'
|
source activate test-environment-$(python.version)
|
||||||
continueOnError: false
|
fi
|
||||||
|
mkdir -p "$SCREENSHOT_DIR"
|
||||||
|
# echo "If Screenshots are generated, they may be downloaded from:"
|
||||||
|
# echo "https://dev.azure.com/pyqtgraph/pyqtgraph/_apis/build/builds/$(Build.BuildId)/artifacts?artifactName=Screenshots&api-version=5.0"
|
||||||
|
python -m pytest -sv \
|
||||||
|
--junitxml=junit/test-results.xml \
|
||||||
|
--cov pyqtgraph --cov-report=xml --cov-report=html
|
||||||
|
displayName: 'Unit tests'
|
||||||
env:
|
env:
|
||||||
DISPLAY: :99.0
|
AZURE: 1
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), ne(variables['agent.os'], 'Windows_NT' ))
|
SCREENSHOT_DIR: $(Build.ArtifactStagingDirectory)/screenshots
|
||||||
|
|
||||||
- script: |
|
- task: PublishBuildArtifacts@1
|
||||||
call activate test_env
|
displayName: 'Publish Screenshots'
|
||||||
python -m pytest --cov pyqtgraph -sv --test-run-title="Tests for $(Agent.OS) - Python $(python.version) - Install Method $(install.method)- Bindings $(qt.bindings)" --napoleon-docstrings
|
condition: failed()
|
||||||
displayName: 'Tests - Run - Conda/Windows'
|
inputs:
|
||||||
continueOnError: false
|
pathtoPublish: $(Build.ArtifactStagingDirectory)/screenshots
|
||||||
env:
|
artifactName: Screenshots
|
||||||
DISPLAY: :99.0
|
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), eq(variables['agent.os'], 'Windows_NT' ))
|
- task: PublishTestResults@2
|
||||||
|
condition: succeededOrFailed()
|
||||||
|
inputs:
|
||||||
|
testResultsFiles: '**/test-*.xml'
|
||||||
|
testRunTitle: 'Test Results for $(agent.os) - $(python.version) - $(qt.bindings) - $(install.method)'
|
||||||
|
publishRunAttachments: true
|
||||||
|
|
||||||
|
- task: PublishCodeCoverageResults@1
|
||||||
|
inputs:
|
||||||
|
codeCoverageTool: Cobertura
|
||||||
|
summaryFileLocation: '$(System.DefaultWorkingDirectory)/**/coverage.xml'
|
||||||
|
reportDirectory: '$(System.DefaultWorkingDirectory)/**/htmlcov'
|
@ -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():
|
||||||
|
@ -213,7 +213,7 @@ def assertImageApproved(image, standardFile, message=None, **kwargs):
|
|||||||
if os.getenv('TRAVIS') is not None:
|
if os.getenv('TRAVIS') is not None:
|
||||||
saveFailedTest(image, stdImage, standardFile, upload=True)
|
saveFailedTest(image, stdImage, standardFile, upload=True)
|
||||||
elif os.getenv('AZURE') is not None:
|
elif os.getenv('AZURE') is not None:
|
||||||
standardFile = r"artifacts/" + standardFile
|
standardFile = os.path.join(os.getenv("SCREENSHOT_DIR", "screenshots"), standardFile)
|
||||||
saveFailedTest(image, stdImage, standardFile)
|
saveFailedTest(image, stdImage, standardFile)
|
||||||
print(graphstate)
|
print(graphstate)
|
||||||
raise
|
raise
|
||||||
@ -288,11 +288,6 @@ def assertImageMatch(im1, im2, minCorr=None, pxThreshold=50.,
|
|||||||
def saveFailedTest(data, expect, filename, upload=False):
|
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'])
|
|
||||||
name = filename.split('/')
|
|
||||||
name.insert(-1, commit.strip())
|
|
||||||
filename = '/'.join(name)
|
|
||||||
|
|
||||||
# concatenate data, expect, and diff into a single image
|
# concatenate data, expect, and diff into a single image
|
||||||
ds = data.shape
|
ds = data.shape
|
||||||
es = expect.shape
|
es = expect.shape
|
||||||
@ -309,7 +304,7 @@ def saveFailedTest(data, expect, filename, upload=False):
|
|||||||
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, _, _ = filename.rpartition("/")
|
directory = os.path.dirname(filename)
|
||||||
if not os.path.isdir(directory):
|
if not os.path.isdir(directory):
|
||||||
os.makedirs(directory)
|
os.makedirs(directory)
|
||||||
with open(filename + ".png", "wb") as png_file:
|
with open(filename + ".png", "wb") as png_file:
|
||||||
@ -317,9 +312,15 @@ def saveFailedTest(data, expect, filename, upload=False):
|
|||||||
print("\nImage comparison failed. Test result: %s %s Expected result: "
|
print("\nImage comparison failed. Test result: %s %s Expected result: "
|
||||||
"%s %s" % (data.shape, data.dtype, expect.shape, expect.dtype))
|
"%s %s" % (data.shape, data.dtype, expect.shape, expect.dtype))
|
||||||
if upload:
|
if upload:
|
||||||
uploadFailedTest(filename)
|
uploadFailedTest(filename, png)
|
||||||
|
|
||||||
|
|
||||||
|
def uploadFailedTest(filename, png):
|
||||||
|
commit = runSubprocess(['git', 'rev-parse', 'HEAD'])
|
||||||
|
name = filename.split(os.path.sep)
|
||||||
|
name.insert(-1, commit.strip())
|
||||||
|
filename = os.path.sep.join(name)
|
||||||
|
|
||||||
def uploadFailedTest(filename):
|
|
||||||
host = 'data.pyqtgraph.org'
|
host = 'data.pyqtgraph.org'
|
||||||
conn = httplib.HTTPConnection(host)
|
conn = httplib.HTTPConnection(host)
|
||||||
req = urllib.urlencode({'name': filename,
|
req = urllib.urlencode({'name': filename,
|
||||||
|
10
pyqtgraph/tests/test_display.py
Normal file
10
pyqtgraph/tests/test_display.py
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
from .. import mkQApp
|
||||||
|
|
||||||
|
qApp = mkQApp()
|
||||||
|
|
||||||
|
|
||||||
|
def test_displayResolution():
|
||||||
|
desktop = qApp.desktop().screenGeometry()
|
||||||
|
width, height = desktop.width(), desktop.height()
|
||||||
|
print("\n\nDisplay Resolution Logged as {}x{}\n\n".format(width, height))
|
||||||
|
assert height > 0 and width > 0
|
7
pyqtgraph/util/get_resolution.py
Normal file
7
pyqtgraph/util/get_resolution.py
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
from .. import mkQApp
|
||||||
|
|
||||||
|
|
||||||
|
def getResolution():
|
||||||
|
qApp = mkQApp()
|
||||||
|
desktop = qApp.desktop().screenGeometry()
|
||||||
|
return (desktop.width(), desktop.height())
|
6
test.py
6
test.py
@ -15,10 +15,10 @@ 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()
|
||||||
|
|
||||||
pytest.main(args)
|
pytest.main(args)
|
||||||
|
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user