rosa-abf/rosa-build

View on GitHub

Showing 182 of 210 total issues

Method perform has a Cognitive Complexity of 16 (exceeds 5 allowed). Consider refactoring.
Open

def perform
return if status == STARTED # do nothing when publication started
extra = options['extra']
repository_status = RepositoryStatus.where(id: extra['repository_status_id']).first
begin
Severity: Minor
Found in app/jobs/abf_worker/publish_observer.rb - About 2 hrs to fix

Method abf_worker_args has a Cognitive Complexity of 16 (exceeds 5 allowed). Consider refactoring.
Open

def abf_worker_args
repos = include_repos
include_repos_hash = {}.tap do |h|
Repository.where(id: (repos | (extra_repositories || [])) ).each do |repo|
path, prefix = repo.platform.public_downloads_url(
Severity: Minor
Found in app/models/build_list.rb - About 2 hrs to fix

Method allowed? has a Cognitive Complexity of 16 (exceeds 5 allowed). Consider refactoring.
Open

def self.allowed?(path, token)
platform_name = path.gsub(/^[\/]+/, '')
.match(/^(#{NAME_PATTERN}\/|#{NAME_PATTERN}$)/)
 
return true unless platform_name
Severity: Minor
Found in app/models/platform.rb - About 2 hrs to fix

Method read_and_write has 52 lines of code (exceeds 25 allowed). Consider refactoring.
Open

def read_and_write(input, stdin, stdout, stderr, timeout=nil, max=nil)
max = nil if max && max <= 0
@out, @err = '', ''
offset = 0
 
 
Severity: Major
Found in lib/ext/posix_spawn.rb - About 2 hrs to fix

    File diff_helper.rb has 253 lines of code (exceeds 250 allowed). Consider refactoring.
    Open

    module DiffHelper
    include CommitHelper
     
    MAX_LINES_WITHOUT_COLLAPSE = 50
     
     
    Severity: Minor
    Found in app/helpers/diff_helper.rb - About 2 hrs to fix

      Method new_comment_notifications has 51 lines of code (exceeds 25 allowed). Consider refactoring.
      Open

      def new_comment_notifications
      return if automatic?
       
      if issue_comment?
      commentable.subscribes.each do |subscribe|
      Severity: Major
      Found in app/models/concerns/feed/comment.rb - About 2 hrs to fix

        Method shift has 51 lines of code (exceeds 25 allowed). Consider refactoring.
        Open

        def shift
        $redis.with do |r|
        job_shift_sem = Redis::Semaphore.new(:job_shift_lock, redis: r)
        job_shift_sem.lock do
        shifted_build_lists = r.smembers('abf_worker:shifted_build_lists')
        Severity: Major
        Found in app/controllers/api/v1/jobs_controller.rb - About 2 hrs to fix

          Method perform has 50 lines of code (exceeds 25 allowed). Consider refactoring.
          Open

          def perform
          return if subject.valid? && restart_task
          if options['feedback_from_user']
          user = User.find options['feedback_from_user']
          return if !user.system? && subject.builder != user
          Severity: Minor
          Found in app/jobs/abf_worker/rpm_worker_observer.rb - About 2 hrs to fix

            Method render_pulls_list has a Cognitive Complexity of 15 (exceeds 5 allowed). Consider refactoring.
            Open

            def render_pulls_list
            @pulls = @pulls.includes(issue: [:user, :assignee])
            if params[:status] == 'closed'
            @pulls = @pulls.closed_or_merged
            else
            Severity: Minor
            Found in app/controllers/api/v1/pull_requests_controller.rb - About 1 hr to fix

            Method default_encoding! has a Cognitive Complexity of 15 (exceeds 5 allowed). Consider refactoring.
            Open

            def default_encoding!
            default_encoding = Encoding.default_internal || Encoding::UTF_8
            if ascii_only? # no need to encode if ascii
            force_encoding(default_encoding)
            else # should encode
            Severity: Minor
            Found in lib/ext/core/string.rb - About 1 hr to fix

            Method show has a Cognitive Complexity of 15 (exceeds 5 allowed). Consider refactoring.
            Open

            def show
            unless request.xhr?
            render('empty') and return if @project.is_empty?
            @tree = @tree / @path if @path.present?
            @commit = @branch.present? ? @branch.commit() : @project.repo.log(@treeish, @path, max_count: 1).first
            Severity: Minor
            Found in app/controllers/projects/git/trees_controller.rb - About 1 hr to fix

            Method init_variables has 46 lines of code (exceeds 25 allowed). Consider refactoring.
            Open

            def init_variables
            case params[:range]
            when RANGE_TWENTY_FOUR_HOURS
            @range_end = Time.now.utc
            @range_start = @range_end - 1.day
            Severity: Minor
            Found in app/controllers/statistics_controller.rb - About 1 hr to fix

              Method index has 46 lines of code (exceeds 25 allowed). Consider refactoring.
              Open

              def index
              params[:kind] = params[:kind] == 'pull_requests' ? 'pull_requests' : 'issues'
              raise Pundit::NotAuthorizedError if !@project.has_issues? && params[:kind] == 'issues'
               
              params[:filter] = params[:filter].in?(['created', 'assigned']) ? params[:filter] : 'all'
              Severity: Minor
              Found in app/controllers/projects/issues_controller.rb - About 1 hr to fix

                Function Typeahead has 45 lines of code (exceeds 25 allowed). Consider refactoring.
                Open

                var Typeahead = function(element, options) {
                //deal with scrollBar
                var defaultOptions=$.fn.typeahead.defaults;
                if(options.scrollBar){
                Severity: Minor
                Found in app/assets/javascripts/lib/bootstrap-typeahead.js - About 1 hr to fix

                  Method show_fail_reason has 44 lines of code (exceeds 25 allowed). Consider refactoring.
                  Open

                  def show_fail_reason
                  respond_to do |format|
                  format.html {
                  @build_lists = @mass_build.build_lists.where(status: BuildList::BUILD_ERROR).page(params[:page])
                  data = @build_lists.pluck(:id, :project_id, :arch_id, :fail_reason)
                  Severity: Minor
                  Found in app/controllers/platforms/mass_builds_controller.rb - About 1 hr to fix

                    Method perform has 44 lines of code (exceeds 25 allowed). Consider refactoring.
                    Open

                    def self.perform(build_list_id, user_id, project_ids, arch_ids, options)
                    build_list = BuildList.find(build_list_id)
                    return if build_list.save_to_platform.personal?
                    user = User.find(user_id)
                     
                     
                    Severity: Minor
                    Found in app/jobs/build_lists/dependent_packages_job.rb - About 1 hr to fix

                      Method build_list has a Cognitive Complexity of 14 (exceeds 5 allowed). Consider refactoring.
                      Open

                      def build_list
                      return @build_list if !!@build_list
                      return nil if @path !~ /\/(release|updates)+\/[\w\-\.\+\~]+$/
                      return nil unless repository_name = @path.match(/\/[\w]+\/(release|updates)\//)
                      repository_name = repository_name[0].gsub(/\/(release|updates)\/$/, '').gsub('/', '')
                      Severity: Minor
                      Found in app/models/platform_content.rb - About 1 hr to fix

                      Method perform has 40 lines of code (exceeds 25 allowed). Consider refactoring.
                      Open

                      def perform
                      return if status == STARTED # do nothing when publication started
                      extra = options['extra']
                      repository_status = RepositoryStatus.where(id: extra['repository_status_id']).first
                      begin
                      Severity: Minor
                      Found in app/jobs/abf_worker/publish_observer.rb - About 1 hr to fix

                        Method parse_projects_platforms has 40 lines of code (exceeds 25 allowed). Consider refactoring.
                        Open

                        def self.parse_projects_platforms(advisory, pr)
                        pr ||= {}
                        if !pr.is_a?(Hash)
                        advisory.errors.add(:base, "Projects is not a hash")
                        return {}
                        Severity: Minor
                        Found in app/services/advisory_service/create.rb - About 1 hr to fix

                          Method show has a Cognitive Complexity of 13 (exceeds 5 allowed). Consider refactoring.
                          Open

                          def show
                          authorize @group
                          respond_to do |format|
                          format.html do
                          @members = @group.members.order(:uname)
                          Severity: Minor
                          Found in app/controllers/groups/profile_controller.rb - About 1 hr to fix
                          Severity
                          Category
                          Status
                          Source
                          Language