xref: /sqlite-3.40.0/test/journal3.test (revision b80bb6ce)
1# 2010 July 15
2#
3# The author disclaims copyright to this source code.  In place of
4# a legal notice, here is a blessing:
5#
6#    May you do good and not evil.
7#    May you find forgiveness for yourself and forgive others.
8#    May you share freely, never taking more than you give.
9#
10#***********************************************************************
11# This file implements regression tests for SQLite library.
12#
13
14set testdir [file dirname $argv0]
15source $testdir/tester.tcl
16source $testdir/lock_common.tcl
17source $testdir/malloc_common.tcl
18
19#-------------------------------------------------------------------------
20# If a connection is required to create a journal file, it creates it with
21# the same file-system permissions as the database file itself. Test this.
22#
23if {$::tcl_platform(platform) == "unix"
24 && [atomic_batch_write test.db]==0
25} {
26
27  # Changed on 2012-02-13:  umask is deliberately ignored for -wal, -journal,
28  # and -shm files.
29  #set umask [exec /bin/sh -c umask]
30  faultsim_delete_and_reopen
31  do_test journal3-1.1 { execsql { CREATE TABLE tx(y, z) } } {}
32
33  foreach {tn permissions} {
34   1 00644
35   2 00666
36   3 00600
37   4 00755
38  } {
39    db close
40    #set effective [format %.5o [expr $permissions & ~$umask]]
41    set effective $permissions
42    do_test journal3-1.2.$tn.1 {
43      catch { forcedelete test.db-journal }
44      file attributes test.db -permissions $permissions
45      file attributes test.db -permissions
46    } $permissions
47    do_test journal3-1.2.$tn.2 { file exists test.db-journal } {0}
48    do_test journal3-1.2.$tn.3 {
49      sqlite3 db test.db
50      execsql {
51        BEGIN;
52          INSERT INTO tx DEFAULT VALUES;
53      }
54      file exists test.db-journal
55    } {1}
56    do_test journal3-1.2.$tn.4 {
57      file attr test.db-journal -perm
58    } $effective
59    do_execsql_test journal3-1.2.$tn.5 { ROLLBACK } {}
60  }
61
62
63}
64
65finish_test
66