quality.rake 2.6 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
def run_pylint(system, report_dir, flags='')
    apps = Dir["#{system}", "#{system}/djangoapps/*", "#{system}/lib/*"].map do |app|
        File.basename(app)
    end.select do |app|
        app !=~ /.pyc$/
    end.map do |app|
        if app =~ /.py$/
            app.gsub('.py', '')
        else
            app
        end
    end

    pythonpath_prefix = "PYTHONPATH=#{system}:#{system}/djangoapps:#{system}/lib:common/djangoapps:common/lib"
    sh("#{pythonpath_prefix} pylint #{flags} -f parseable #{apps.join(' ')} | tee #{report_dir}/pylint.report")
end

18 19 20 21 22

[:lms, :cms, :common].each do |system|
    report_dir = report_dir_path(system)
    directory report_dir

23 24 25 26 27 28 29
    namespace :pylint do
        namespace system do
            desc "Run pylint checking for #{system} checking for errors only, and aborting if there are any"
            task :errors do
                run_pylint(system, report_dir, '-E')
            end
        end
30

31
        desc "Run pylint on all #{system} code"
32
        task system => [report_dir, :install_python_prereqs] do
33
            run_pylint(system, report_dir)
34 35
        end
    end
36
    task :pylint => :"pylint:#{system}"
37

38 39 40 41 42 43 44 45
    namespace :pep8 do
        desc "Run pep8 on all #{system} code"
        task system => [report_dir, :install_python_prereqs] do
            sh("pep8 #{system} | tee #{report_dir}/pep8.report")
        end
    end
    task :pep8 => :"pep8:#{system}"
end
46 47 48 49 50

dquality_dir = File.join(REPORT_DIR, "diff_quality")
directory dquality_dir

desc "Build the html diff quality reports, and print the reports to the console."
51 52
task :quality => [dquality_dir, :install_python_prereqs] do

53
    # Generage diff-quality html report for pep8, and print to console
54 55 56 57 58
    # If pep8 reports exist, use those
    # Otherwise, `diff-quality` will call pep8 itself
    pep8_reports = FileList[File.join(REPORT_DIR, '**/pep8.report')].join(' ')
    sh("diff-quality --violations=pep8 --html-report #{dquality_dir}/diff_quality_pep8.html #{pep8_reports}")
    sh("diff-quality --violations=pep8 #{pep8_reports}")
59 60

    # Generage diff-quality html report for pylint, and print to console
61 62 63
    # If pylint reports exist, use those
    # Otherwise, `diff-quality` will call pylint itself
    pylint_reports = FileList[File.join(REPORT_DIR, '**/pylint.report')].join(' ')
64
    pythonpath_prefix = "PYTHONPATH=$PYTHONPATH:lms:lms/djangoapps:lms/lib:cms:cms/djangoapps:cms/lib:common:common/djangoapps:common/lib"
65 66 67
    sh("#{pythonpath_prefix} diff-quality --violations=pylint --html-report #{dquality_dir}/diff_quality_pylint.html #{pylint_reports}")
    sh("#{pythonpath_prefix} diff-quality --violations=pylint #{pylint_reports}")
end