Commit 4b56fc29 by Will Daly

Merge pull request #2301 from edx/will/bok-choy-coverage

Collect coverage for bok-choy tests
parents 48a5c760 23a1947a
...@@ -44,6 +44,7 @@ conf/locale/ko_KR ...@@ -44,6 +44,7 @@ conf/locale/ko_KR
.noseids .noseids
nosetests.xml nosetests.xml
.coverage .coverage
.coverage.*
coverage.xml coverage.xml
cover/ cover/
cover_html/ cover_html/
......
[run]
data_file = reports/bok_choy/.coverage
source = lms, cms, common/djangoapps, common/lib
omit = lms/envs/*, cms/envs/*, common/djangoapps/terrain/*, common/djangoapps/*/migrations/*, */test*, */management/*, */urls*, */wsgi*
parallel = True
[report]
ignore_errors = True
[html]
title = Bok Choy Test Coverage Report
directory = reports/bok_choy/cover
[xml]
output = reports/bok_choy/coverage.xml
...@@ -12,11 +12,16 @@ BOK_CHOY_NUM_PARALLEL = ENV.fetch('NUM_PARALLEL', 1).to_i ...@@ -12,11 +12,16 @@ BOK_CHOY_NUM_PARALLEL = ENV.fetch('NUM_PARALLEL', 1).to_i
BOK_CHOY_TEST_TIMEOUT = ENV.fetch("TEST_TIMEOUT", 300).to_f BOK_CHOY_TEST_TIMEOUT = ENV.fetch("TEST_TIMEOUT", 300).to_f
# Ensure that we have a directory to put logs and reports # Ensure that we have a directory to put logs and reports
BOK_CHOY_TEST_DIR = File.join(REPO_ROOT, "common", "test", "acceptance", "tests") BOK_CHOY_DIR = File.join(REPO_ROOT, "common", "test", "acceptance")
BOK_CHOY_TEST_DIR = File.join(BOK_CHOY_DIR, "tests")
BOK_CHOY_LOG_DIR = File.join(REPO_ROOT, "test_root", "log") BOK_CHOY_LOG_DIR = File.join(REPO_ROOT, "test_root", "log")
directory BOK_CHOY_LOG_DIR directory BOK_CHOY_LOG_DIR
BOK_CHOY_XUNIT_REPORT = report_dir_path("bok_choy_xunit.xml") # Reports
BOK_CHOY_REPORT_DIR = report_dir_path("bok_choy")
BOK_CHOY_XUNIT_REPORT = File.join(BOK_CHOY_REPORT_DIR, "xunit.xml")
BOK_CHOY_COVERAGE_RC = File.join(BOK_CHOY_DIR, ".coveragerc")
directory BOK_CHOY_REPORT_DIR
BOK_CHOY_SERVERS = { BOK_CHOY_SERVERS = {
...@@ -31,10 +36,8 @@ BOK_CHOY_CACHE = Dalli::Client.new('localhost:11211') ...@@ -31,10 +36,8 @@ BOK_CHOY_CACHE = Dalli::Client.new('localhost:11211')
def start_servers() def start_servers()
BOK_CHOY_SERVERS.each do | service, info | BOK_CHOY_SERVERS.each do | service, info |
address = "0.0.0.0:#{info[:port]}" address = "0.0.0.0:#{info[:port]}"
singleton_process( cmd = "coverage run --rcfile=#{BOK_CHOY_COVERAGE_RC} -m manage #{service} --settings bok_choy runserver #{address} --traceback --noreload"
django_admin(service, 'bok_choy', 'runserver', address), singleton_process(cmd, logfile=info[:log])
logfile=info[:log]
)
end end
end end
...@@ -166,7 +169,9 @@ namespace :'test:bok_choy' do ...@@ -166,7 +169,9 @@ namespace :'test:bok_choy' do
end end
desc "Run acceptance tests that use the bok-choy framework but skip setup" desc "Run acceptance tests that use the bok-choy framework but skip setup"
task :fast, [:test_spec] => [:check_services, BOK_CHOY_LOG_DIR] do |t, args| task :fast, [:test_spec] => [
:check_services, BOK_CHOY_LOG_DIR, BOK_CHOY_REPORT_DIR, :clean_reports_dir
] do |t, args|
# Ensure the test servers are available # Ensure the test servers are available
puts "Starting test servers...".red puts "Starting test servers...".red
...@@ -186,6 +191,17 @@ namespace :'test:bok_choy' do ...@@ -186,6 +191,17 @@ namespace :'test:bok_choy' do
end end
end end
desc "Generate coverage reports for bok-choy tests"
task :coverage => BOK_CHOY_REPORT_DIR do | t, args |
puts "Combining coverage reports".red
sh("coverage combine --rcfile=#{BOK_CHOY_COVERAGE_RC}")
puts "Generating coverage reports".red
sh("coverage html --rcfile=#{BOK_CHOY_COVERAGE_RC}")
sh("coverage xml --rcfile=#{BOK_CHOY_COVERAGE_RC}")
sh("coverage report --rcfile=#{BOK_CHOY_COVERAGE_RC}")
end
end end
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment