mirror of
https://github.com/frappe/bench.git
synced 2025-01-10 00:37:51 +00:00
[Minor] Add extra test case for checking ports
* Added routine to find the max_cpus on the machine to start appropriate number of workers * Modified supervisor.conf to get webserver_port for multi-bench setup
This commit is contained in:
parent
68dc8cbfd4
commit
a12cffacca
@ -41,7 +41,9 @@ def generate_supervisor_config(bench='.', user=None):
|
|||||||
"node": find_executable('node') or find_executable('nodejs'),
|
"node": find_executable('node') or find_executable('nodejs'),
|
||||||
"redis_cache_config": os.path.join(bench_dir, 'config', 'redis_cache.conf'),
|
"redis_cache_config": os.path.join(bench_dir, 'config', 'redis_cache.conf'),
|
||||||
"redis_async_broker_config": os.path.join(bench_dir, 'config', 'redis_async_broker.conf'),
|
"redis_async_broker_config": os.path.join(bench_dir, 'config', 'redis_async_broker.conf'),
|
||||||
"frappe_version": get_current_frappe_version()
|
"frappe_version": get_current_frappe_version(),
|
||||||
|
"webserver_port": config.get('webserver_port'),
|
||||||
|
"n_workers": config.get('max_workers')
|
||||||
})
|
})
|
||||||
write_config_file(bench, 'supervisor.conf', config)
|
write_config_file(bench, 'supervisor.conf', config)
|
||||||
update_config({'restart_supervisor_on_update': True})
|
update_config({'restart_supervisor_on_update': True})
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
; killasgroup=true --> send kill signal to child processes too
|
; killasgroup=true --> send kill signal to child processes too
|
||||||
|
|
||||||
[program:frappe-web]
|
[program:frappe-web]
|
||||||
command={{ bench_dir }}/env/bin/gunicorn -b 127.0.0.1:8000 -w 2 -t {{http_timeout}} frappe.app:application
|
command={{ bench_dir }}/env/bin/gunicorn -b 127.0.0.1:{{webserver_port}} -w {{n_workers}} -t {{http_timeout}} frappe.app:application
|
||||||
priority=4
|
priority=4
|
||||||
autostart=true
|
autostart=true
|
||||||
autorestart=true
|
autorestart=true
|
||||||
|
@ -5,6 +5,7 @@ import bench.utils
|
|||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
import shutil
|
import shutil
|
||||||
|
import socket
|
||||||
|
|
||||||
class TestBenchInit(unittest.TestCase):
|
class TestBenchInit(unittest.TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
@ -22,9 +23,6 @@ class TestBenchInit(unittest.TestCase):
|
|||||||
|
|
||||||
bench.utils.init(bench_name)
|
bench.utils.init(bench_name)
|
||||||
|
|
||||||
# logging
|
|
||||||
self.assert_exists(bench_name, "logs", "bench.log")
|
|
||||||
|
|
||||||
self.assert_folders(bench_name)
|
self.assert_folders(bench_name)
|
||||||
|
|
||||||
self.assert_virtual_env(bench_name)
|
self.assert_virtual_env(bench_name)
|
||||||
@ -37,10 +35,24 @@ class TestBenchInit(unittest.TestCase):
|
|||||||
|
|
||||||
def test_multiple_benches(self):
|
def test_multiple_benches(self):
|
||||||
self.test_init("test-bench-1")
|
self.test_init("test-bench-1")
|
||||||
self.assert_ports("test-bench-1")
|
test_bench_1_ports = {
|
||||||
|
"webserver_port": 8000,
|
||||||
|
"socketio_port": 9000,
|
||||||
|
"redis_celery_broker_port": 11000,
|
||||||
|
"redis_async_broker_port": 12000,
|
||||||
|
"redis_cache_port": 13000
|
||||||
|
}
|
||||||
|
self.assert_ports("test-bench-1", test_bench_1_ports)
|
||||||
|
|
||||||
self.test_init("test-bench-2")
|
self.test_init("test-bench-2")
|
||||||
self.assert_ports("test-bench-2")
|
test_bench_2_ports = {
|
||||||
|
"webserver_port": 8001,
|
||||||
|
"socketio_port": 9001,
|
||||||
|
"redis_celery_broker_port": 11001,
|
||||||
|
"redis_async_broker_port": 12001,
|
||||||
|
"redis_cache_port": 13001
|
||||||
|
}
|
||||||
|
self.assert_ports("test-bench-2", test_bench_2_ports)
|
||||||
|
|
||||||
def assert_folders(self, bench_name):
|
def assert_folders(self, bench_name):
|
||||||
for folder in bench.utils.folders_in_bench:
|
for folder in bench.utils.folders_in_bench:
|
||||||
@ -61,6 +73,7 @@ class TestBenchInit(unittest.TestCase):
|
|||||||
config_json = os.path.exists(os.path.join(bench_name, "config.json"))
|
config_json = os.path.exists(os.path.join(bench_name, "config.json"))
|
||||||
self.assertTrue(config_json)
|
self.assertTrue(config_json)
|
||||||
with open(config_json, "r") as f:
|
with open(config_json, "r") as f:
|
||||||
|
print f
|
||||||
config_dict = json.loads(f.read().decode("utf-8"))
|
config_dict = json.loads(f.read().decode("utf-8"))
|
||||||
for key, value in bench.utils.default_config.items():
|
for key, value in bench.utils.default_config.items():
|
||||||
self.assertEquals(config_dict.get(key), value)
|
self.assertEquals(config_dict.get(key), value)
|
||||||
@ -81,9 +94,14 @@ class TestBenchInit(unittest.TestCase):
|
|||||||
self.assert_exists(bench_name, "node_modules")
|
self.assert_exists(bench_name, "node_modules")
|
||||||
self.assert_exists(bench_name, "node_modules", "socket.io")
|
self.assert_exists(bench_name, "node_modules", "socket.io")
|
||||||
|
|
||||||
def assert_ports(self, bench_name):
|
def assert_ports(self, bench_name, ports):
|
||||||
pass
|
config_path = os.path.join(self.benches_path, bench_name, 'config', 'config.json')
|
||||||
|
|
||||||
|
with open(config_path, "r") as f:
|
||||||
|
config_json = json.load(f)
|
||||||
|
|
||||||
|
for key, port in ports:
|
||||||
|
self.assertEqual(config_json.get(key), port)
|
||||||
|
|
||||||
def assert_exists(self, *args):
|
def assert_exists(self, *args):
|
||||||
self.assert_exists(*args)
|
self.assertTrue(os.path.exists(os.path.join(*args)))
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@ default_config = {
|
|||||||
'rebase_on_pull': False,
|
'rebase_on_pull': False,
|
||||||
'update_bench_on_update': True,
|
'update_bench_on_update': True,
|
||||||
'frappe_user': getpass.getuser(),
|
'frappe_user': getpass.getuser(),
|
||||||
'shallow_clone': True
|
'shallow_clone': True,
|
||||||
}
|
}
|
||||||
|
|
||||||
folders_in_bench = ('apps', 'sites', 'config', 'logs', 'config/files')
|
folders_in_bench = ('apps', 'sites', 'config', 'logs', 'config/files')
|
||||||
@ -95,8 +95,17 @@ def make_bench_config():
|
|||||||
bench_config = {}
|
bench_config = {}
|
||||||
bench_config.update(default_config)
|
bench_config.update(default_config)
|
||||||
bench_config.update(make_ports())
|
bench_config.update(make_ports())
|
||||||
|
bench_config.update(get_max_worker_count())
|
||||||
|
|
||||||
return bench_config
|
return bench_config
|
||||||
|
|
||||||
|
def get_max_worker_count():
|
||||||
|
'''This function will return the maximum workers that can be started depending upon'''
|
||||||
|
'''number of cpu's present on the machine'''
|
||||||
|
n_cpus = multiprocessing.cpu_count()
|
||||||
|
return dict(max_workers=2 * n_cpus)
|
||||||
|
|
||||||
|
|
||||||
def make_ports(benches_path="."):
|
def make_ports(benches_path="."):
|
||||||
default_ports = {
|
default_ports = {
|
||||||
"webserver_port": 8000,
|
"webserver_port": 8000,
|
||||||
|
Loading…
Reference in New Issue
Block a user