commit
478d4c5a86
@ -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,146 @@ 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' )
|
||||||
|
|
||||||
- bash: |
|
- task: UsePythonVersion@0
|
||||||
echo "##vso[task.prependpath]$CONDA/bin"
|
inputs:
|
||||||
sudo chown -R $USER $CONDA
|
versionSpec: $(python.version)
|
||||||
displayName: 'MacOS - Add conda to PATH'
|
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), eq(variables['agent.os'], 'Darwin' ))
|
|
||||||
|
|
||||||
- bash: |
|
|
||||||
brew update && brew install azure-cli
|
|
||||||
brew update && brew install python3 && brew upgrade python3
|
|
||||||
brew link --overwrite python3
|
|
||||||
displayName: "MacOS - Intall Python3"
|
|
||||||
condition: and(eq(variables['install.method'], 'pip' ), eq(variables['agent.os'], 'Darwin' ))
|
|
||||||
|
|
||||||
- bash: |
|
|
||||||
echo "##vso[task.prependpath]/usr/share/miniconda/bin"
|
|
||||||
displayName: 'Linux - Add conda to PATH'
|
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), eq(variables['agent.os'], 'Linux' ))
|
|
||||||
|
|
||||||
- bash: |
|
|
||||||
# Install & Start Windows Manager for Linux
|
|
||||||
sudo apt-get install -y xvfb libxkbcommon-x11-0 # herbstluftwm
|
|
||||||
displayName: 'Linux - Prepare OS'
|
|
||||||
condition: eq(variables['agent.os'], 'Linux' )
|
|
||||||
|
|
||||||
- bash: |
|
|
||||||
source $HOME/miniconda/etc/profile.d/conda.sh
|
|
||||||
hash -r
|
|
||||||
conda config --set always_yes yes --set auto_update_conda no
|
|
||||||
conda config --add channels conda-forge
|
|
||||||
conda create -n test_env --quiet python=$(python.version)
|
|
||||||
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')
|
condition: eq(variables['install.method'], 'pip')
|
||||||
|
|
||||||
- bash: |
|
- bash: |
|
||||||
source activate test_env
|
if [ $(agent.os) == 'Linux' ]
|
||||||
echo python location: `which python3`
|
then
|
||||||
echo python version: `python3 --version`
|
echo '##vso[task.prependpath]/usr/share/miniconda/bin'
|
||||||
echo pytest location: `which pytest`
|
elif [ $(agent.os) == 'Darwin' ]
|
||||||
echo installed packages
|
then
|
||||||
conda list
|
echo '##vso[task.prependpath]$CONDA/bin'
|
||||||
echo pyqtgraph system info
|
sudo install -d -m 0777 /usr/local/miniconda/envs
|
||||||
python -c "import pyqtgraph as pg; pg.systemInfo()"
|
elif [ $(agent.os) == 'Windows_NT' ]
|
||||||
displayName: 'Debug - Conda/MacOS+Linux'
|
then
|
||||||
continueOnError: false
|
echo "##vso[task.prependpath]$env:CONDA\Scripts"
|
||||||
condition: and(eq(variables['install.method'], 'conda' ), ne(variables['agent.os'], 'Windows_NT' ))
|
else
|
||||||
|
echo 'Just what OS are you using?'
|
||||||
|
fi
|
||||||
|
displayName: 'Add Conda to $PATH'
|
||||||
|
condition: eq(variables['install.method'], 'conda' )
|
||||||
|
|
||||||
- script: |
|
- task: CondaEnvironment@0
|
||||||
call activate test_env
|
displayName: 'Create Conda Environment'
|
||||||
echo python location
|
condition: eq(variables['install.method'], 'conda')
|
||||||
where python
|
inputs:
|
||||||
echo python version
|
environmentName: 'test-environment-$(python.version)'
|
||||||
python --version
|
packageSpecs: 'python=$(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: |
|
- bash: |
|
||||||
echo python location: `which python3`
|
if [ $(install.method) == "conda" ]
|
||||||
echo python version: `python3 --version`
|
then
|
||||||
echo pytest location: `which pytest`
|
source activate test-environment-$(python.version)
|
||||||
echo installed packages
|
conda install -c conda-forge $(qt.bindings) numpy scipy pyopengl pytest flake8 six coverage --yes
|
||||||
pip3 list
|
else
|
||||||
echo pyqtgraph system info
|
pip install $(qt.bindings) numpy scipy pyopengl pytest flake8 six coverage
|
||||||
python3 -c "import pyqtgraph as pg; pg.systemInfo()"
|
fi
|
||||||
displayName: 'Debug - System/MacOS+Linux'
|
pip install pytest-xdist pytest-cov pytest-faulthandler
|
||||||
continueOnError: false
|
displayName: "Install Dependencies"
|
||||||
condition: and(eq(variables['install.method'], 'pip' ), ne(variables['agent.os'], 'Windows_NT' ))
|
|
||||||
|
|
||||||
- bash: |
|
- bash: |
|
||||||
echo python location: `where python`
|
if [ $(install.method) == "conda" ]
|
||||||
|
then
|
||||||
|
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: |
|
||||||
|
sudo apt-get install -y libxkbcommon-x11-0 # herbstluftwm
|
||||||
|
if [ $(install.method) == "conda" ]
|
||||||
|
then
|
||||||
|
source activate test-environment-$(python.version)
|
||||||
|
fi
|
||||||
|
pip install pytest-xvfb
|
||||||
|
displayName: "Linux Virtual Display Setup"
|
||||||
|
condition: eq(variables['agent.os'], 'Linux' )
|
||||||
|
|
||||||
|
- bash: |
|
||||||
|
if [ $(install.method) == "conda" ]
|
||||||
|
then
|
||||||
|
source activate test-environment-$(python.version)
|
||||||
|
fi
|
||||||
|
echo python location: `which 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 \
|
||||||
|
--faulthandler-timeout=60
|
||||||
|
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'
|
@ -1553,7 +1553,7 @@ class RectROI(ROI):
|
|||||||
self.addScaleHandle([0.5, 1], [0.5, center[1]])
|
self.addScaleHandle([0.5, 1], [0.5, center[1]])
|
||||||
|
|
||||||
class LineROI(ROI):
|
class LineROI(ROI):
|
||||||
"""
|
r"""
|
||||||
Rectangular ROI subclass with scale-rotate handles on either side. This
|
Rectangular ROI subclass with scale-rotate handles on either side. This
|
||||||
allows the ROI to be positioned as if moving the ends of a line segment.
|
allows the ROI to be positioned as if moving the ends of a line segment.
|
||||||
A third handle controls the width of the ROI orthogonal to its "line" axis.
|
A third handle controls the width of the ROI orthogonal to its "line" axis.
|
||||||
|
@ -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(os.path.sep)
|
|
||||||
name.insert(-1, commit.strip())
|
|
||||||
filename = os.path.sep.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
|
||||||
@ -319,7 +314,13 @@ def saveFailedTest(data, expect, filename, upload=False):
|
|||||||
if upload:
|
if upload:
|
||||||
uploadFailedTest(filename, png)
|
uploadFailedTest(filename, png)
|
||||||
|
|
||||||
|
|
||||||
def 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)
|
||||||
|
|
||||||
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())
|
5
test.py
5
test.py
@ -21,9 +21,4 @@ elif '--pyside2' in args:
|
|||||||
|
|
||||||
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…
x
Reference in New Issue
Block a user