Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Windows CI #674

Open
wants to merge 17 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
56 changes: 56 additions & 0 deletions azure-pipelines.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
pool:
vmImage: 'windows-latest'

variables:
PYTHON_VERSION: 3.6

Comment on lines +3 to +6
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On Windows, the python version must be> = 3.6 to install atari-py.

jobs:
- template: azure_templates/run-test.yml
parameters:
name: 'UnitTests_a_d'
PYTHON_VERSION: $(PYTHON_VERSION)
GLOB: '[a-d]*'
- template: azure_templates/run-test.yml
parameters:
name: 'UnitTests_e_h'
PYTHON_VERSION: $(PYTHON_VERSION)
GLOB: '[e-h]*'
- template: azure_templates/run-test.yml
parameters:
name: 'UnitTests_i_lo'
PYTHON_VERSION: $(PYTHON_VERSION)
GLOB: '[i-lo]*'
- template: azure_templates/run-test.yml
parameters:
name: 'UnitTests_lp_lz'
PYTHON_VERSION: $(PYTHON_VERSION)
GLOB: '[lp-lz]*'
- template: azure_templates/run-test.yml
parameters:
name: 'UnitTests_m_r'
PYTHON_VERSION: $(PYTHON_VERSION)
GLOB: '[m-r]*'
- template: azure_templates/run-test.yml
parameters:
name: 'UnitTests_s'
PYTHON_VERSION: $(PYTHON_VERSION)
GLOB: 's*'
- template: azure_templates/run-test.yml
parameters:
name: 'UnitTests_t_z'
PYTHON_VERSION: $(PYTHON_VERSION)
GLOB: '[t-z]*'
- template: azure_templates/run-test.yml
parameters:
name: 'UnitTests_determinism'
PYTHON_VERSION: $(PYTHON_VERSION)
GLOB: '0deterministic.py'
- job: Test_mpi_adam
steps:
- task: UsePythonVersion@0
inputs:
versionSpec: $(PYTHON_VERSION)
- template: azure_templates/install-msmpi.yml
- template: azure_templates/install-python-package.yml
- script: bash -c "python -m stable_baselines.common.mpi_adam"
displayName: 'Run test'
9 changes: 9 additions & 0 deletions azure_templates/install-msmpi.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
steps:
- task: PowerShell@2
inputs:
targetType: 'inline'
script: |
Invoke-WebRequest "https://github.com/microsoft/Microsoft-MPI/releases/download/v10.1.1/msmpisetup.exe" -OutFile $pwd\msmpisetup.exe ;
Start-Process $pwd\msmpisetup.exe -ArgumentList '-unattend' -Wait ;
Remove-Item $pwd\msmpisetup.exe -Force ;
Get-CimInstance -Class Win32_Product | Where-Object Name -like "Microsoft MPI*"
7 changes: 7 additions & 0 deletions azure_templates/install-python-package.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
steps:
- script: |
python -m pip install --upgrade pip --user
python -m pip install --upgrade setuptools
python -m pip install tensorflow==1.14.0
python -m pip install -e .[mpi,tests,docs]
displayName: 'Install python package'
10 changes: 10 additions & 0 deletions azure_templates/run-test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
jobs:
- job: ${{ parameters.name }}
steps:
- task: UsePythonVersion@0
inputs:
versionSpec: ${{ parameters.PYTHON_VERSION }}
- template: install-msmpi.yml
- template: install-python-package.yml
- script: bash -c "python -m pytest --cov-config .coveragerc --cov-report term --cov=. -v tests/test_${{ parameters.GLOB }}"
displayName: 'Run test'
3 changes: 2 additions & 1 deletion docs/misc/changelog.rst
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ Others:
- Removed redundant return value from `a2c.utils::total_episode_reward_logger`. (@shwang)
- Cleanup and refactoring in `common/identity_env.py` (@shwang)
- Added a Makefile to simplify common development tasks (build the doc, type check, run the tests)
- Add windows CI (@ChengYen-Tang)

Documentation:
^^^^^^^^^^^^^^
Expand Down Expand Up @@ -614,4 +615,4 @@ Thanks to @bjmuld @iambenzo @iandanforth @r7vme @brendenpetersen @huvar @abhiskk
@XMaster96 @kantneel @Pastafarianist @GerardMaggiolino @PatrickWalter214 @yutingsz @sc420 @Aaahh @billtubbs
@Miffyli @dwiel @miguelrass @qxcv @jaberkow @eavelardev @ruifeng96150 @pedrohbtp @srivatsankrishnan @evilsocket
@MarvineGothic @jdossgollin @SyllogismRXS @rusu24edward @jbulow @Antymon @seheevic @justinkterry @edbeeching
@flodorner @KuKuXia @NeoExtended
@flodorner @KuKuXia @NeoExtended @ChengYen-Tang
11 changes: 9 additions & 2 deletions setup.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import os
import sys
import subprocess
import platform
from setuptools import setup, find_packages
from distutils.version import LooseVersion

Expand Down Expand Up @@ -39,6 +40,13 @@ def find_tf_dependency():

return tf_dependency

def other_tests_packages():
if platform.system() == 'Windows':
return []
elif platform.system() == 'Darwin': # Mac OS X
return ['pytype']
else:
return ['pytype']

Comment on lines 42 to 50
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pytype is currently not support windows.

long_description = """
[![Build Status](https://travis-ci.com/hill-a/stable-baselines.svg?branch=master)](https://travis-ci.com/hill-a/stable-baselines) [![Documentation Status](https://readthedocs.org/projects/stable-baselines/badge/?version=master)](https://stable-baselines.readthedocs.io/en/master/?badge=master) [![Codacy Badge](https://api.codacy.com/project/badge/Grade/3bcb4cd6d76a4270acb16b5fe6dd9efa)](https://www.codacy.com/app/baselines_janitors/stable-baselines?utm_source=github.com&utm_medium=referral&utm_content=hill-a/stable-baselines&utm_campaign=Badge_Grade) [![Codacy Badge](https://api.codacy.com/project/badge/Coverage/3bcb4cd6d76a4270acb16b5fe6dd9efa)](https://www.codacy.com/app/baselines_janitors/stable-baselines?utm_source=github.com&utm_medium=referral&utm_content=hill-a/stable-baselines&utm_campaign=Badge_Coverage)
Expand Down Expand Up @@ -135,8 +143,7 @@ def find_tf_dependency():
'pytest-cov',
'pytest-env',
'pytest-xdist',
'pytype',
],
] + other_tests_packages(),
'docs': [
'sphinx',
'sphinx-autobuild',
Expand Down
16 changes: 12 additions & 4 deletions tests/test_monitor.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
import uuid
import json
import os
import sys
import warnings

import pandas
import gym
Expand All @@ -15,7 +17,7 @@ def test_monitor():
"""
env = gym.make("CartPole-v1")
env.seed(0)
mon_file = "/tmp/stable_baselines-test-{}.monitor.csv".format(uuid.uuid4())
mon_file = "./stable_baselines-test-{}.monitor.csv".format(uuid.uuid4())
menv = Monitor(env, mon_file)
menv.reset()
for _ in range(1000):
Expand All @@ -34,7 +36,10 @@ def test_monitor():
last_logline = pandas.read_csv(file_handler, index_col=None)
assert set(last_logline.keys()) == {'l', 't', 'r'}, "Incorrect keys in monitor logline"
file_handler.close()
os.remove(mon_file)
try:
os.remove(mon_file)
except PermissionError:
warnings.warn(str(sys.exc_info()[1]))

def test_monitor_load_results(tmp_path):
"""
Expand Down Expand Up @@ -82,5 +87,8 @@ def test_monitor_load_results(tmp_path):

assert results_size2 == (results_size1 + episode_count2)

os.remove(monitor_file1)
os.remove(monitor_file2)
try:
os.remove(monitor_file1)
os.remove(monitor_file2)
except PermissionError:
warnings.warn(str(sys.exc_info()[1]))
20 changes: 15 additions & 5 deletions tests/test_mpi_adam.py
Original file line number Diff line number Diff line change
@@ -1,18 +1,28 @@
import platform
import subprocess

from .test_common import _assert_eq


def test_mpi_adam():
"""Test RunningMeanStd object for MPI"""
return_code = subprocess.call(['mpirun', '--allow-run-as-root', '-np', '2',
'python', '-m', 'stable_baselines.common.mpi_adam'])
if platform.system() == 'Windows':
return_code = subprocess.call(['mpiexec', '-np', '2',
'python', '-m', 'stable_baselines.common.mpi_adam'])
else:
return_code = subprocess.call(['mpirun', '--allow-run-as-root', '-np', '2',
'python', '-m', 'stable_baselines.common.mpi_adam'])
_assert_eq(return_code, 0)


def test_mpi_adam_ppo1():
"""Running test for ppo1"""
return_code = subprocess.call(['mpirun', '--allow-run-as-root', '-np', '2',
'python', '-m',
'stable_baselines.ppo1.experiments.train_cartpole'])
if platform.system() == 'Windows':
return_code = subprocess.call(['mpiexec', '-np', '2',
'python', '-m',
'stable_baselines.ppo1.experiments.train_cartpole'])
else:
return_code = subprocess.call(['mpirun', '--allow-run-as-root', '-np', '2',
'python', '-m',
'stable_baselines.ppo1.experiments.train_cartpole'])
_assert_eq(return_code, 0)
20 changes: 15 additions & 5 deletions tests/test_vec_normalize.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import platform
import subprocess

import gym
Expand Down Expand Up @@ -125,15 +126,24 @@ def test_normalize_external():

def test_mpi_runningmeanstd():
"""Test RunningMeanStd object for MPI"""
return_code = subprocess.call(['mpirun', '--allow-run-as-root', '-np', '2',
'python', '-m', 'stable_baselines.common.mpi_running_mean_std'])
if platform.system() == 'Windows':
return_code = subprocess.call(['mpiexec', '-np', '2',
'python', '-m', 'stable_baselines.common.mpi_running_mean_std'])
else:
return_code = subprocess.call(['mpirun', '--allow-run-as-root', '-np', '2',
'python', '-m', 'stable_baselines.common.mpi_running_mean_std'])
_assert_eq(return_code, 0)


def test_mpi_moments():
"""
test running mean std function
"""
subprocess.check_call(['mpirun', '--allow-run-as-root', '-np', '3', 'python', '-c',
'from stable_baselines.common.mpi_moments '
'import _helper_runningmeanstd; _helper_runningmeanstd()'])
if platform.system() == 'Windows':
subprocess.check_call(['mpiexec', '-np', '3', 'python', '-c',
'from stable_baselines.common.mpi_moments '
'import _helper_runningmeanstd; _helper_runningmeanstd()'])
else:
subprocess.check_call(['mpirun', '--allow-run-as-root', '-np', '3', 'python', '-c',
'from stable_baselines.common.mpi_moments '
'import _helper_runningmeanstd; _helper_runningmeanstd()'])