| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
 | # encoding: utf-8
$:.unshift "../lib"
require 'th_mauve'
require 'mauve/datamapper'
require 'mauve/server'
require 'mauve/configuration'
require 'mauve/configuration_builder'
require 'mauve/configuration_builders'
class TcMauveDatabasePeculiarities < Mauve::UnitTest
  include Mauve
  def setup
    super
    setup_database
    @temp_db = "mauve_test.#{10.times.collect{ rand(36).to_s(36) }.join}"
  end
  def teardown
    teardown_database
    super
  end
  def test_encoding
    #
    # Don't test unless the DB URL has been set.
    #
    return unless @db_url
    config=<<EOF
server {
  database "#{@db_url}"
}
EOF
    Configuration.current = ConfigurationBuilder.parse(config)
    Server.instance.setup
    x = Hash.new
    x["en"] = "Please rush me my portable walrus polishing kit!"
    x["fi"] = "Ole hyvä kiirehtiä minulle kannettavan mursu kiillotukseen pakki!"
    x["jp"] = "私に私のポータブルセイウチの研磨キットを急いでください!"
    %w(UTF-8 WINDOWS-1252 SJIS).each do |enc|
      x.each do |lang, str|
        assert_nothing_raised("Failed to use iconv to convert to #{enc}") {
          str = str.encode(enc, :invalid => :replace, :undef => :replace, :replace => '?')
        }
        alert = Alert.new(
          :alert_id  => "#{lang}:#{enc}",
          :source    => "test",
          :subject   => str
        )
        assert_nothing_raised("failed to insert #{enc}") { alert.save }
      end
    end
  end
end
class TcMauveDatabasePostgresPeculiarities < TcMauveDatabasePeculiarities
  def setup
    super
    system("createdb #{@temp_db} --encoding UTF8")
    unless $?.success?
      msg = "Skipping postgres tests, as DB creation (#{@temp_db}) failed."
      @temp_db = nil
      skip(msg)
    end
    # @pg_conn = PGconn.open(:dbname => @temp_db)
    @db_url = "postgres:///#{@temp_db}"
  end
  def teardown
    # @pg_conn.finish if @pg_conn.is_a?(PGconn) and @pg_conn.status == PGconn::CONNECTION_OK
    super
    (system("dropdb #{@temp_db}") || puts("Failed to drop #{@temp_db}")) if @temp_db
  end
  def test_reminders_only_go_once
    config=<<EOF
server {
  database "#{@db_url}"
  use_notification_buffer  false
}
notification_method("email") {
  debug!
  deliver_to_queue []
  disable_normal_delivery!
}
person ("test1") {
  email "test1@example.com"
  all { email }
  suppress_notifications_after( 1 => 1 )
}
alert_group("default") {
  notify("test1") {
    during{ true }
    every 1.minute
  }
}
EOF
    Configuration.current = ConfigurationBuilder.parse(config)
    notification_buffer = Configuration.current.notification_methods["email"].deliver_to_queue
    Server.instance.setup
     a = Alert.new(
      :alert_id  => "test",
      :source    => "test",
      :subject   => "test"
    )
    assert(a.raise!, "raise was not successful")
    assert(a.saved?)
    assert_equal(1, notification_buffer.length)
    notification_buffer.pop
    10.times do
      Timecop.freeze(Time.now + 1.minute)
      5.times do
        AlertChanged.all.each do |ac|
          assert(ac.poll)
        end
      end
      assert_equal(1, notification_buffer.length)
      notification_buffer.pop
    end
  end
end
class TcMauveDatabaseSqlite3Peculiarities < TcMauveDatabasePeculiarities
  def setup
    super
    # @pg_conn = PGconn.open(:dbname => @temp_db)
    @db_url = "sqlite3::memory:"
  end
  #
  # This just makes sure our mixin has been added to the SqliteAdapter.
  #
  def test_has_mixin
    assert DataMapper::Adapters::SqliteAdapter.private_instance_methods.include?(:with_connection_old)
    assert DataMapper::Adapters::SqliteAdapter.public_instance_methods.include?(:synchronize)
  end
end
 |