2019-12-26 10:16:55 +00:00
|
|
|
;;; Guix Data Service -- Information about Guix over time
|
|
|
|
|
;;; Copyright © 2019 Christopher Baines <mail@cbaines.net>
|
|
|
|
|
;;;
|
|
|
|
|
;;; This program is free software: you can redistribute it and/or
|
|
|
|
|
;;; modify it under the terms of the GNU Affero General Public License
|
|
|
|
|
;;; as published by the Free Software Foundation, either version 3 of
|
|
|
|
|
;;; the License, or (at your option) any later version.
|
|
|
|
|
;;;
|
|
|
|
|
;;; This program is distributed in the hope that it will be useful,
|
|
|
|
|
;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
;;; Affero General Public License for more details.
|
|
|
|
|
;;;
|
|
|
|
|
;;; You should have received a copy of the GNU Affero General Public
|
|
|
|
|
;;; License along with this program. If not, see
|
|
|
|
|
;;; <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
2019-08-31 12:11:58 +01:00
|
|
|
(define-module (guix-data-service model lint-checker)
|
|
|
|
|
#:use-module (srfi srfi-1)
|
|
|
|
|
#:use-module (ice-9 match)
|
2019-08-31 12:42:28 +01:00
|
|
|
#:use-module (squee)
|
2019-08-31 12:11:58 +01:00
|
|
|
#:use-module (guix-data-service model utils)
|
2019-08-31 12:42:28 +01:00
|
|
|
#:export (lint-checkers->lint-checker-ids
|
2019-09-01 13:35:23 +01:00
|
|
|
lint-warning-count-by-lint-checker-for-revision
|
2019-09-01 14:10:53 +01:00
|
|
|
insert-guix-revision-lint-checkers
|
2020-05-28 22:17:11 +02:00
|
|
|
lint-checkers-for-revision
|
2020-06-06 18:20:14 +02:00
|
|
|
lint-checker-description-data->lint-checker-description-set-id
|
|
|
|
|
insert-lint-checker-description-set))
|
2019-08-31 12:11:58 +01:00
|
|
|
|
|
|
|
|
(define (lint-checkers->lint-checker-ids conn lint-checkers-data)
|
|
|
|
|
(insert-missing-data-and-return-all-ids
|
|
|
|
|
conn
|
|
|
|
|
"lint_checkers"
|
2020-05-28 22:17:11 +02:00
|
|
|
'(name network_dependent lint_checker_description_set_id)
|
2019-08-31 12:11:58 +01:00
|
|
|
lint-checkers-data))
|
2019-08-31 12:42:28 +01:00
|
|
|
|
2020-05-28 22:17:11 +02:00
|
|
|
(define (lint-checker-description-data->lint-checker-description-ids
|
|
|
|
|
conn descriptions-by-locale)
|
|
|
|
|
(insert-missing-data-and-return-all-ids
|
|
|
|
|
conn
|
|
|
|
|
"lint_checker_descriptions"
|
|
|
|
|
'(locale description)
|
|
|
|
|
(map (match-lambda
|
|
|
|
|
((locale . description)
|
|
|
|
|
(list locale description)))
|
|
|
|
|
descriptions-by-locale)))
|
|
|
|
|
|
|
|
|
|
(define (insert-lint-checker-description-set conn lint-description-ids)
|
|
|
|
|
(let ((query
|
|
|
|
|
(string-append
|
|
|
|
|
"INSERT INTO lint_checker_description_sets (description_ids) VALUES "
|
|
|
|
|
(string-append
|
|
|
|
|
"('{"
|
|
|
|
|
(string-join
|
|
|
|
|
(map number->string
|
|
|
|
|
(sort lint-description-ids <))
|
|
|
|
|
", ")
|
|
|
|
|
"}')")
|
|
|
|
|
" RETURNING id")))
|
|
|
|
|
(match (exec-query conn query)
|
|
|
|
|
(((id)) id))))
|
|
|
|
|
|
|
|
|
|
(define (lint-checker-description-data->lint-checker-description-set-id
|
|
|
|
|
conn
|
|
|
|
|
descriptions-by-locale)
|
|
|
|
|
(let* ((lint-checker-description-ids
|
|
|
|
|
(lint-checker-description-data->lint-checker-description-ids
|
|
|
|
|
conn
|
|
|
|
|
descriptions-by-locale))
|
|
|
|
|
(lint-checker-description-set-id
|
|
|
|
|
(exec-query
|
|
|
|
|
conn
|
|
|
|
|
(string-append
|
|
|
|
|
"SELECT id FROM lint_checker_description_sets"
|
|
|
|
|
" WHERE description_ids = ARRAY["
|
|
|
|
|
(string-join (map number->string
|
|
|
|
|
(sort lint-checker-description-ids <)) ", ")
|
|
|
|
|
"]"))))
|
|
|
|
|
(string->number
|
|
|
|
|
(match lint-checker-description-set-id
|
|
|
|
|
(((id)) id)
|
|
|
|
|
(()
|
|
|
|
|
(insert-lint-checker-description-set conn lint-checker-description-ids))))))
|
|
|
|
|
|
|
|
|
|
|
2019-08-31 12:42:28 +01:00
|
|
|
(define (lint-warning-count-by-lint-checker-for-revision conn commit-hash)
|
|
|
|
|
(define query
|
|
|
|
|
"
|
2020-05-28 22:17:11 +02:00
|
|
|
SELECT lint_checkers.name, lint_checker_descriptions.description,
|
2019-08-31 12:42:28 +01:00
|
|
|
lint_checkers.network_dependent, revision_data.count
|
|
|
|
|
FROM lint_checkers
|
2020-05-28 22:17:11 +02:00
|
|
|
INNER JOIN lint_checker_description_sets
|
|
|
|
|
ON lint_checkers.lint_checker_description_set_id = lint_checker_description_sets.id
|
|
|
|
|
INNER JOIN lint_checker_descriptions
|
|
|
|
|
ON lint_checker_descriptions.id = ANY (lint_checker_description_sets.description_ids)
|
2020-09-26 11:45:57 +01:00
|
|
|
AND lint_checker_descriptions.locale = 'en_US.UTF-8'
|
2019-08-31 12:42:28 +01:00
|
|
|
INNER JOIN (
|
|
|
|
|
SELECT lint_checker_id, COUNT(*)
|
|
|
|
|
FROM lint_warnings
|
|
|
|
|
WHERE id IN (
|
|
|
|
|
SELECT lint_warning_id
|
|
|
|
|
FROM guix_revision_lint_warnings
|
|
|
|
|
INNER JOIN guix_revisions
|
|
|
|
|
ON guix_revision_lint_warnings.guix_revision_id = guix_revisions.id
|
|
|
|
|
WHERE commit = $1
|
|
|
|
|
)
|
|
|
|
|
GROUP BY lint_checker_id
|
|
|
|
|
) AS revision_data ON lint_checkers.id = revision_data.lint_checker_id
|
|
|
|
|
ORDER BY count DESC")
|
|
|
|
|
|
|
|
|
|
(exec-query conn query (list commit-hash)))
|
2019-09-01 13:35:23 +01:00
|
|
|
|
|
|
|
|
(define (insert-guix-revision-lint-checkers conn
|
|
|
|
|
guix-revision-id
|
|
|
|
|
lint-checker-ids)
|
|
|
|
|
(exec-query
|
|
|
|
|
conn
|
|
|
|
|
(string-append
|
|
|
|
|
"INSERT INTO guix_revision_lint_checkers (lint_checker_id, guix_revision_id) "
|
|
|
|
|
"VALUES "
|
|
|
|
|
(string-join
|
|
|
|
|
(map (lambda (lint-checker-id)
|
|
|
|
|
(simple-format
|
|
|
|
|
#f
|
|
|
|
|
"(~A, ~A)"
|
|
|
|
|
lint-checker-id
|
|
|
|
|
guix-revision-id))
|
|
|
|
|
lint-checker-ids)
|
|
|
|
|
", "))))
|
2019-09-01 14:10:53 +01:00
|
|
|
|
|
|
|
|
(define (lint-checkers-for-revision conn commit-hash)
|
|
|
|
|
(exec-query
|
|
|
|
|
conn
|
|
|
|
|
"
|
2020-05-28 22:17:11 +02:00
|
|
|
SELECT lint_checkers.name, lint_checker_descriptions.description, lint_checkers.network_dependent
|
2019-09-01 14:10:53 +01:00
|
|
|
FROM lint_checkers
|
2020-05-28 22:17:11 +02:00
|
|
|
INNER JOIN lint_checker_description_sets
|
|
|
|
|
ON lint_checkers.lint_checker_description_set_id = lint_checker_description_sets.id
|
|
|
|
|
INNER JOIN lint_checker_descriptions
|
|
|
|
|
ON lint_checker_descriptions.id = ANY (lint_checker_description_sets.description_ids)
|
2020-09-26 11:45:57 +01:00
|
|
|
AND lint_checker_descriptions.locale = 'en_US.UTF-8'
|
2020-05-28 22:17:11 +02:00
|
|
|
WHERE lint_checkers.id IN (
|
2019-09-01 14:10:53 +01:00
|
|
|
SELECT lint_checker_id
|
|
|
|
|
FROM guix_revision_lint_checkers
|
|
|
|
|
INNER JOIN guix_revisions
|
|
|
|
|
ON guix_revisions.id = guix_revision_lint_checkers.guix_revision_id
|
2020-05-28 23:00:10 +02:00
|
|
|
WHERE commit = $1)"
|
2019-09-01 14:10:53 +01:00
|
|
|
(list commit-hash)))
|