12533: Add client IP address & authorization token UUID to the logs.
[arvados.git] / services / api / Rakefile
1 #!/usr/bin/env rake
2 # Copyright (C) The Arvados Authors. All rights reserved.
3 #
4 # SPDX-License-Identifier: AGPL-3.0
5
6 # Add your own tasks in files placed in lib/tasks ending in .rake,
7 # for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
8
9 require File.expand_path('../config/application', __FILE__)
10
11 Server::Application.load_tasks
12
13 namespace :test do
14   task(:run).clear
15   # Copied from the definition in Rails 3.2.
16   # This may need to be updated if we upgrade Rails.
17   task :run do
18     errors = %w(test:units test:functionals test:integration test:tasks).collect do |task|
19       begin
20         Rake::Task[task].invoke
21         nil
22       rescue => e
23         { :task => task, :exception => e }
24       end
25     end.compact
26
27     if errors.any?
28       puts errors.map { |e| "Errors running #{e[:task]}! #{e[:exception].inspect}" }.join("\n")
29       abort
30     end
31   end
32 end
33
34 namespace :db do
35   namespace :structure do
36     task :dump do
37       require 'tempfile'
38       origfnm = File.expand_path('../db/structure.sql', __FILE__)
39       tmpfnm = Tempfile.new 'structure.sql', File.expand_path('..', origfnm)
40       copyright_done = false
41       started = false
42       begin
43         tmpfile = File.new tmpfnm, 'w'
44         origfile = File.new origfnm
45         origfile.each_line do |line|
46           if !copyright_done
47             if !/Copyright .* Arvados/.match(line)
48                tmpfile.write "-- Copyright (C) The Arvados Authors. All rights reserved.\n--\n-- SPDX-License-Identifier: AGPL-3.0\n\n"
49             end
50             copyright_done = true
51           end
52
53           if !started && /^[^-\n]/ !~ line
54             # Ignore the "PostgreSQL database dump" comment block,
55             # which varies from one client version to the next.
56             next
57           end
58           started = true
59
60           if /^SET (lock_timeout|idle_in_transaction_session_timeout|row_security) = / =~ line
61             # Avoid edit wars between versions that do/don't write (and can/can't execute) this line.
62             next
63           elsif /^COMMENT ON EXTENSION/ =~ line
64             # Avoid warning message when loading:
65             # "structure.sql:22: ERROR:  must be owner of extension plpgsql"
66             tmpfile.write "-- "
67           end
68           tmpfile.write line
69         end
70         origfile.close
71         tmpfile.close
72         File.rename tmpfnm, origfnm
73         tmpfnm = false
74       ensure
75         File.unlink tmpfnm if tmpfnm
76       end
77     end
78   end
79 end
80
81 # Work around Rails3+PostgreSQL9.5 incompatibility (pg_dump used to
82 # accept -i as a no-op, but now it's not accepted at all).
83 module Kernel
84   alias_method :orig_backtick, :`
85   def `(*args) #`#` sorry, parsers
86     args[0].sub!(/\Apg_dump -i /, 'pg_dump ') rescue nil
87     orig_backtick(*args)
88   end
89 end