blob: 2010d67657a9c46b8e1f26f0d42b62a4a49a1e14 [file] [log] [blame]
drh48a296c2021-05-27 16:31:04 +00001#!/usr/bin/tcl
2#
3# Run this script to test to see that the latest trunk changes can be
4# merged into LTS branches without breaking anything.
5#
6# To Use:
7#
8# * Copy this script into a directory above the sqlite checkout
9# * Run "fossil update trunk" and "fossil revert"
10# * Run "tclsh ../merge-test.tcl" (in other words run this script)
11#
12# Operation:
13#
14# This script changes to each LTS branch to be tested, merges the latest
15# trunk changes into the branch (without committing them) and then
16# runs "make test". Any errors are stored in local files.
17#
18# Limitations:
19#
20# Some LTS branches are not synced directly from trunk but rather from
21# other LTS branches. These other branches cannot be tested because
22# there is no good way to generate the intermediate merges.
23#
24###############################################################################
25
26# Run a shell command contained in arguments. Put the return code in
27# global variable ::res and the output string in global variable ::result
28#
29proc safeexec {args} {
30 global res result
31 set res [catch "exec $args" result]
32}
33
34# Run the shell command contained in arguments. Print an error and exit
35# if anything goes wrong.
36#
37proc mustbeok {args} {
38 global res result
39 set res [catch "exec $args" result]
40 if {$res} {
41 puts "FAILED: $args"
42 puts $result
43 exit 1
44 }
45}
46
47# Write $content into a file named $filename. The file is overwritten if it
48# already exist. The file is create if it does not already exist.
49#
50proc writefile {filename content} {
51 set fd [open $filename wb]
52 puts $fd $content
53 close $fd
54}
55
56# Run the merge-test
57#
58foreach {branch configopts} {
59 begin-concurrent {--enable-json1}
60 begin-concurrent-pnu {--enable-json1}
61 wal2 {--enable-all}
62 reuse-schema {--enable-all}
63} {
64 puts $branch
65 set errorfile ${branch}-error.txt
66 mustbeok fossil revert
67 mustbeok fossil up $branch
68 safeexec fossil merge trunk
69 if {$res} {
70 puts " merge failed - see $errorfile"
71 writefile $errorfile $result
72 } else {
73 puts " merge ok"
74 safeexec ./configure --enable-debug {*}$configopts
75 if {$res} {
76 puts " configure failed - see $errorfile"
77 writefile $errorfile $result
78 } else {
79 puts " configure ok"
80 safeexec make fuzzcheck sqlite3 testfixture
81 if {$res} {
82 puts " build failed - see $errorfile"
83 writefile $errorfile $result
84 } else {
85 puts " build ok"
86 safeexec make test
87 if {$res} {
88 puts " test failed - see $errorfile"
89 writefile $errorfile $result
90 } else {
91 puts " test ok"
92 }
93 }
94 }
95 }
96}
97mustbeok fossil revert
98mustbeok fossil up trunk
99puts "reset back to trunk"