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

Convert bash scripts to Python #7465

Merged
merged 156 commits into from
Sep 8, 2019
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
156 commits
Select commit Hold shift + click to select a range
6ac0724
initial
Aug 17, 2019
13c37f9
fix lint
Aug 18, 2019
9ae6f2e
fix
Aug 18, 2019
2eca67e
fix
Aug 18, 2019
c9b6f98
conver
Aug 19, 2019
7218092
fix
Aug 19, 2019
9250dcb
fix
Aug 19, 2019
9d33246
convert
Aug 19, 2019
41113da
fix
Aug 19, 2019
4fe2b2d
Merge branch 'develop' into convert_bash_1
Aug 20, 2019
406129e
Merge branch 'develop' into convert_bash_1
Aug 21, 2019
beb3c52
add
Aug 22, 2019
77e21d7
convert
Aug 22, 2019
c5e3c97
fix lint
Aug 22, 2019
a5eebeb
convert
Aug 22, 2019
f9a8586
convert
Aug 22, 2019
afb7068
Merge branch 'develop' into convert_bash_1
Aug 23, 2019
dc1845c
convert
Aug 23, 2019
eee27b9
convert
Aug 24, 2019
a6dc5bb
convert
Aug 24, 2019
e88fd13
address
Aug 24, 2019
c373919
fix path
Aug 24, 2019
06dc081
convert
Aug 24, 2019
6b57f85
Merge branch 'develop' into convert_bash_1
Aug 25, 2019
845a94c
remove files
Aug 25, 2019
4df7247
convert
Aug 25, 2019
d3a2464
fix comment
Aug 25, 2019
275d886
convert
Aug 25, 2019
3482864
convert
Aug 25, 2019
0ab00ec
fix
Aug 25, 2019
cbb09a7
address comments
Aug 25, 2019
d2ed087
convert
Aug 25, 2019
1ced71c
convert
Aug 25, 2019
60510ae
fix lint
Aug 25, 2019
f83f917
update circleci
Aug 25, 2019
fb26396
fix
Aug 25, 2019
d0a9f56
convert
Aug 25, 2019
df0c880
fix
Aug 25, 2019
af66d95
fix
Aug 25, 2019
48c8ce8
fix
Aug 25, 2019
fcbbbb0
fix
Aug 25, 2019
0af2fc4
Merge branch 'develop' into convert_bash_1
Aug 25, 2019
d3f80a3
sync with develop
Aug 25, 2019
740eb7a
fix
Aug 25, 2019
c6ae74b
fix conflicts
Aug 26, 2019
2834e82
use parse known args
Aug 26, 2019
8bbda96
remove user
Aug 26, 2019
cd84f0b
fix pip
Aug 27, 2019
2c03e24
try subprocess on pip install
Aug 27, 2019
cd4a824
fix
Aug 27, 2019
ae51254
fix
Aug 27, 2019
a7e21c5
fix
Aug 27, 2019
e9fd69d
fix
Aug 27, 2019
b26d7dc
fix
Aug 27, 2019
33a10ce
add node path
Aug 27, 2019
8ba23a5
fix
Aug 27, 2019
db7a003
fix lint
Aug 27, 2019
f521c7a
add args
Aug 27, 2019
b6d5878
fix lint
Aug 27, 2019
3086329
merge develo
Aug 27, 2019
b912d6d
add path
Aug 27, 2019
efabda0
address comments
Aug 27, 2019
899228a
address comments
Aug 27, 2019
6044c23
fix
Aug 27, 2019
c28656b
fix
Aug 27, 2019
2d62316
fix
Aug 27, 2019
1e7bcdb
fix
Aug 27, 2019
3a97331
fix frontend
Aug 28, 2019
cfad6b3
fix
Aug 28, 2019
11ae549
fix start
Aug 28, 2019
46eb948
fix lint
Aug 28, 2019
95b6ca9
clear cache
Aug 28, 2019
7130eb7
revert
Aug 28, 2019
13155a5
remove pylint
Aug 28, 2019
86647a8
remove pylint path
Aug 28, 2019
7c47253
add path
Aug 28, 2019
efc69b0
add pylint path
Aug 28, 2019
834bffa
fix
Aug 28, 2019
0186a8a
fix
Aug 28, 2019
326eda8
use vurtual env
Aug 28, 2019
4f4b3c2
fix
Aug 28, 2019
ad9fbae
fix
Aug 28, 2019
34efc74
add url in travis yaml
Aug 28, 2019
2d3d642
test
Aug 28, 2019
dcf6ec3
test
Aug 28, 2019
b532ba0
fix
Aug 28, 2019
f58f27a
test
Aug 28, 2019
93b7cf4
test
Aug 28, 2019
01970a5
test
Aug 28, 2019
eda2856
test
Aug 28, 2019
92d39d5
test
Aug 28, 2019
98b324b
test
Aug 28, 2019
4cc089c
test
Aug 28, 2019
2f2871c
tes
Aug 28, 2019
14d2659
fi
Aug 28, 2019
862490c
fix
Aug 28, 2019
1ec120f
test
Aug 28, 2019
9386c0c
fix conflicts
Aug 29, 2019
11d891d
fix
Aug 29, 2019
07eaf2b
Merge branch 'develop' into convert_bash_1
Aug 30, 2019
ce7d114
fix
Aug 30, 2019
6f04c1b
fix test
Aug 30, 2019
767d97e
fix
Aug 30, 2019
82804cb
fix conflicts
Aug 31, 2019
8e43243
fix
Aug 31, 2019
fabf517
address comments
Aug 31, 2019
8b7bb5a
fix
Aug 31, 2019
057f2e6
fix node
Aug 31, 2019
8003bfe
fix
Aug 31, 2019
25b64ad
remove vagrant
Aug 31, 2019
0492abe
fix
Aug 31, 2019
fd168ab
address comments
Aug 31, 2019
77ddcbc
fix conflicts
Aug 31, 2019
d89c3b0
fix lint
Aug 31, 2019
251669a
fix
Aug 31, 2019
b07b0d9
fix
Aug 31, 2019
03e56b7
address comments
Aug 31, 2019
770cd4f
fix
Aug 31, 2019
fafbde2
fix
Sep 1, 2019
9ec9238
fix
Sep 1, 2019
33f38a7
fix
Sep 1, 2019
35cfe60
fix
Sep 1, 2019
af6ad16
merge develop
Sep 2, 2019
55a1a99
address comments
Sep 2, 2019
c604eae
fix
Sep 2, 2019
90b50d8
fix
Sep 2, 2019
5bdc8b1
fix
Sep 2, 2019
891d088
only one backend_tests.py
Sep 2, 2019
a6e6b28
address comments
Sep 2, 2019
a42a17c
Merge branch 'develop' into convert_bash_1
Sep 2, 2019
28eaabe
fix
Sep 2, 2019
6e9b993
fix
Sep 2, 2019
7bf028d
fix
Sep 2, 2019
f0ebb60
fix
Sep 2, 2019
8fe8d20
fix errors
Sep 2, 2019
b73afbf
address comments
Sep 2, 2019
1b4638b
fix
Sep 2, 2019
64fc6c5
use None and args
Sep 2, 2019
320b65e
fix permission
Sep 2, 2019
127cead
fix
Sep 2, 2019
595be3c
fix conflicts
Sep 2, 2019
6939582
address comments
Sep 2, 2019
80a9599
fix e2e
Sep 3, 2019
5ac03b0
address comments
Sep 3, 2019
9a84e6f
fix
Sep 3, 2019
770c6f3
fix
Sep 3, 2019
d713208
skip e2e
Sep 3, 2019
c3006d2
remove yaml
Sep 3, 2019
2459c84
fix lint
Sep 3, 2019
89f61e6
use single quotes
Sep 4, 2019
07814eb
fix conflicts
Sep 7, 2019
89afe82
fix conflicts
Sep 7, 2019
6967564
test
Sep 7, 2019
6ba9902
fix linr
Sep 7, 2019
943759b
add tests
Sep 8, 2019
911d84a
use triple strings
Sep 8, 2019
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
Prev Previous commit
Next Next commit
fix
  • Loading branch information
Rishav Chakraborty committed Aug 31, 2019
commit 8003bfe03813217ff3e746aedd07ae9f5adb4e14
10 changes: 6 additions & 4 deletions scripts/create_expression_parser.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,8 +45,9 @@ def main():
expression_parser_definition, expression_parser_js])

for line in fileinput.input(files=[expression_parser_js], inplace=True):
# Inside this loop the STDOUT will be redirected to the file.
# The end='' is needed to avoid double line breaks.
# Inside this loop the STDOUT will be redirected to the file,
# expression_parser_js. The end='' is needed to avoid double line
# breaks.
python_utils.PRINT(
brianrodri marked this conversation as resolved.
Show resolved Hide resolved
re.sub(
r'module\.exports.*$',
Expand All @@ -55,8 +56,9 @@ def main():
line), end='')

for line in fileinput.input(files=[expression_parser_js], inplace=True):
# Inside this loop the STDOUT will be redirected to the file.
# The end='' is needed to avoid double line breaks.
# Inside this loop the STDOUT will be redirected to the file,
# expression_parser_js. The end='' is needed to avoid double line
# breaks.
python_utils.PRINT(
re.sub(r'^\}\)\(\);\s*$', '}]);', line), end='')

Expand Down
36 changes: 13 additions & 23 deletions scripts/install_third_party_libs.py
Original file line number Diff line number Diff line change
Expand Up @@ -56,8 +56,7 @@ def pip_install(package, version, install_path):
except ImportError:
common.print_each_string_after_two_new_lines([
'Pip is required to install Oppia dependencies, but pip wasn\'t '
'found',
'on your local machine.',
'found on your local machine.',
'Please see \'Installing Oppia\' on the Oppia developers\' wiki '
'page:'])

Expand All @@ -74,7 +73,7 @@ def pip_install(package, version, install_path):
python_utils.PRINT(
'https://github.com/oppia/oppia/wiki/Installing-Oppia-%28'
'Windows%29')
sys.exit(1)
raise Exception

# For pip version < 10.
Copy link
Member

Choose a reason for hiding this comment

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

Shouldn't we be specifying an exact pip version that developers should install?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

We should use the latest version of pip I think but circleCI uses pip version 9.

Copy link
Member

Choose a reason for hiding this comment

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

OK, perhaps leave a comment here.

Should we configure CircleCI to use a later version of pip? (Optional, though, and I think it's out of scope for the project. Only mentioning in case it's an easy option.)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Removed this as now subprocess is used

if hasattr(pip, 'main'):
brianrodri marked this conversation as resolved.
Show resolved Hide resolved
Expand Down Expand Up @@ -113,6 +112,8 @@ def install_skulpt(argv):
if not os.path.exists(
os.path.join(common.OPPIA_TOOLS_DIR, 'skulpt-0.10.0')):
python_utils.PRINT('Downloading Skulpt')
skulpt_filepath = os.path.join(
common.OPPIA_TOOLS_DIR, 'skulpt-0.10.0', 'skulpt', 'skulpt.py')
os.chdir(common.OPPIA_TOOLS_DIR)
os.mkdir('skulpt-0.10.0')
os.chdir('skulpt-0.10.0')
Expand All @@ -129,29 +130,23 @@ def install_skulpt(argv):
# and generating documentation and are not necessary when building
# Skulpt.
for line in fileinput.input(
files=[os.path.join(
common.OPPIA_TOOLS_DIR,
'skulpt-0.10.0/skulpt/skulpt.py')], inplace=True):
# Inside this loop the STDOUT will be redirected to the file.
# The end='' is needed to avoid double line breaks.
files=[skulpt_filepath], inplace=True):
# Inside this loop the STDOUT will be redirected to the file,
# skulpt.py. The end='' is needed to avoid double line breaks.
python_utils.PRINT(
line.replace('ret = test()', 'ret = 0'),
end='')

for line in fileinput.input(
files=[os.path.join(
common.OPPIA_TOOLS_DIR,
'skulpt-0.10.0/skulpt/skulpt.py')], inplace=True):
# Inside this loop the STDOUT will be redirected to the file.
# The end='' is needed to avoid double line breaks.
files=[skulpt_filepath], inplace=True):
# Inside this loop the STDOUT will be redirected to the file,
# skulpt.py. The end='' is needed to avoid double line breaks.
python_utils.PRINT(
line.replace(' doc()', ' pass#doc()'),
end='')

for line in fileinput.input(
files=[os.path.join(
common.OPPIA_TOOLS_DIR,
'skulpt-0.10.0/skulpt/skulpt.py')], inplace=True):
files=[skulpt_filepath], inplace=True):
# This and the next command disable unit and compressed unit
# tests for the compressed distribution of Skulpt. These
# tests don't work on some Ubuntu environments and cause a
Expand All @@ -163,17 +158,12 @@ def install_skulpt(argv):
end='')

for line in fileinput.input(
files=[os.path.join(
common.OPPIA_TOOLS_DIR,
'skulpt-0.10.0/skulpt/skulpt.py')], inplace=True):
files=[skulpt_filepath], inplace=True):
python_utils.PRINT(
line.replace('ret = rununits(opt=True)', 'ret = 0'),
end='')

subprocess.call([
'python', os.path.join(
common.OPPIA_TOOLS_DIR, 'skulpt-0.10.0/skulpt/skulpt.py'),
'dist'])
subprocess.call(['python', skulpt_filepath, 'dist'])

# Return to the Oppia root folder.
os.chdir(common.CURR_DIR)
Expand Down
16 changes: 8 additions & 8 deletions scripts/run_e2e_tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ def cleanup():
while common.is_port_open(4444) or common.is_port_open(9001):
time.sleep(1)

if os.path.isdir('../protractor-screenshots'):
if os.path.isdir(os.path.join('..', 'protractor-screenshots')):
common.print_each_string_after_two_new_lines([
'Note: If ADD_SCREENSHOT_REPORTER is set to true in',
'core/tests/protractor.conf.js, you can view screenshots',
Expand All @@ -102,14 +102,14 @@ def main(argv=None):
'There is already a server running on localhost:8181.',
'Please terminate it before running the end-to-end tests.',
'Exiting.'])
sys.exit(1)
raise Exception

if common.is_port_open(9001):
common.print_each_string_after_two_new_lines([
'There is already a server running on localhost:9001.',
'Please terminate it before running the end-to-end tests.',
'Exiting.'])
sys.exit(1)
raise Exception

# Forces the cleanup function to run on exit.
# Developers: note that at the end of this script, the cleanup() function at
Expand All @@ -122,8 +122,8 @@ def main(argv=None):
constants_env_variable = '\'DEV_MODE\': false'
for line in fileinput.input(
files=['assets/constants.ts'], inplace=True):
# Inside this loop the STDOUT will be redirected to the file.
# The end='' is needed to avoid double line breaks.
# Inside this loop the STDOUT will be redirected to the file,
# constants.ts. The end='' is needed to avoid double line breaks.
python_utils.PRINT(
re.sub(r'\'DEV_MODE\': .*', constants_env_variable, line),
end='')
Expand All @@ -134,8 +134,8 @@ def main(argv=None):
constants_env_variable = '\'DEV_MODE\': true'
for line in fileinput.input(
files=['assets/constants.ts'], inplace=True):
# Inside this loop the STDOUT will be redirected to the file.
# The end='' is needed to avoid double line breaks.
# Inside this loop the STDOUT will be redirected to the file,
# constants.ts. The end='' is needed to avoid double line breaks.
python_utils.PRINT(
re.sub(r'\'DEV_MODE\': .*', constants_env_variable, line),
end='')
Expand Down Expand Up @@ -173,7 +173,7 @@ def main(argv=None):
time.sleep(1)

# Delete outdated screenshots.
if os.path.isdir('../protractor-screenshots'):
if os.path.isdir(os.path.join('..', 'protractor-screenshots')):
shutil.rmtree('../protractor-screenshots')

# Run the end-to-end tests. The conditional is used to run protractor
Expand Down
2 changes: 1 addition & 1 deletion scripts/run_performance_tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ def main(argv=None):
'There is already a server running on localhost:8181',
'Please terminate it before running the performance tests.',
'Exiting.'])
sys.exit(1)
raise Exception

# Forces the cleanup function to run on exit.
# Developers: note that at the end of this script, the cleanup() function at
Expand Down
8 changes: 4 additions & 4 deletions scripts/setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ def test_python_version():
'https://stackoverflow.com/questions/3701646/how-to-add-to-the-'
'pythonpath-in-windows-7'])
# Exit when no suitable Python environment can be found.
sys.exit(1)
raise Exception


def main():
Expand All @@ -90,7 +90,7 @@ def main():
python_utils.PRINT(
'WARNING This script should be run from the oppia/ root folder.')
python_utils.PRINT('')
sys.exit(1)
raise Exception

# Set COMMON_DIR to the absolute path of the directory above OPPIA_DIR. This
# is necessary becaue COMMON_DIR (or subsequent variables which refer to it)
Expand All @@ -111,7 +111,7 @@ def main():
'https://github.com/oppia/oppia/wiki/Installing-Oppia-%28Windows'
'%29',
'STATUS: Installation completed except for node.js. Exiting.'])
sys.exit(1)
raise Exception

# Download and install node.js.
python_utils.PRINT(
Expand Down Expand Up @@ -184,7 +184,7 @@ def main():
'/Applications/Google Chrome.app/Contents/MacOS/Google Chrome')
else:
python_utils.PRINT('Chrome is not found, stopping ...')
sys.exit(1)
raise Exception

os.environ['CHROME_BIN'] = chrome_bin
python_utils.PRINT('Environment setup completed.')
Expand Down
4 changes: 2 additions & 2 deletions scripts/setup_gae.py
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ def main():
'google_appengine_1.9.67.zip', filename='gae-download.zip')
except Exception:
python_utils.PRINT('Error downloading Google App Engine. Exiting.')
sys.exit(1)
raise Exception
python_utils.PRINT('Download complete. Installing Google App Engine...')
with zipfile.ZipFile('gae-download.zip', 'r') as zip_ref:
zip_ref.extractall(
Expand All @@ -83,7 +83,7 @@ def main():
filename='gcloud-sdk.tar.gz')
except Exception:
python_utils.PRINT('Error downloading Google Cloud SDK. Exiting.')
sys.exit(1)
raise Exception
python_utils.PRINT('Download complete. Installing Google Cloud SDK...')
tar = tarfile.open(name='gcloud-sdk.tar.gz')
tar.extractall(
Expand Down
8 changes: 4 additions & 4 deletions scripts/start.py
Original file line number Diff line number Diff line change
Expand Up @@ -97,8 +97,8 @@ def main(argv=None):
constants_env_variable = '\'DEV_MODE\': false'
for line in fileinput.input(
files=['assets/constants.ts'], inplace=True):
# Inside this loop the STDOUT will be redirected to the file.
# The end='' is needed to avoid double line breaks.
# Inside this loop the STDOUT will be redirected to the file,
# constants.ts. The end='' is needed to avoid double line breaks.
python_utils.PRINT(
re.sub(
r'\'DEV_MODE\': .*', constants_env_variable, line), end='')
Expand All @@ -108,8 +108,8 @@ def main(argv=None):
constants_env_variable = '\'DEV_MODE\': true'
for line in fileinput.input(
files=['assets/constants.ts'], inplace=True):
# Inside this loop the STDOUT will be redirected to the file.
# The end='' is needed to avoid double line breaks.
# Inside this loop the STDOUT will be redirected to the file,
# constants.ts. The end='' is needed to avoid double line breaks.
python_utils.PRINT(
re.sub(
r'\'DEV_MODE\': .*', constants_env_variable, line), end='')
Expand Down