file_monitoring 0.0.4 → 0.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,500 @@
1
+ 0
2
+ 1
3
+ 2
4
+ 3
5
+ 4
6
+ 5
7
+ 6
8
+ 7
9
+ 8
10
+ 9
11
+ 10
12
+ 11
13
+ 12
14
+ 13
15
+ 14
16
+ 15
17
+ 16
18
+ 17
19
+ 18
20
+ 19
21
+ 20
22
+ 21
23
+ 22
24
+ 23
25
+ 24
26
+ 25
27
+ 26
28
+ 27
29
+ 28
30
+ 29
31
+ 30
32
+ 31
33
+ 32
34
+ 33
35
+ 34
36
+ 35
37
+ 36
38
+ 37
39
+ 38
40
+ 39
41
+ 40
42
+ 41
43
+ 42
44
+ 43
45
+ 44
46
+ 45
47
+ 46
48
+ 47
49
+ 48
50
+ 49
51
+ 50
52
+ 51
53
+ 52
54
+ 53
55
+ 54
56
+ 55
57
+ 56
58
+ 57
59
+ 58
60
+ 59
61
+ 60
62
+ 61
63
+ 62
64
+ 63
65
+ 64
66
+ 65
67
+ 66
68
+ 67
69
+ 68
70
+ 69
71
+ 70
72
+ 71
73
+ 72
74
+ 73
75
+ 74
76
+ 75
77
+ 76
78
+ 77
79
+ 78
80
+ 79
81
+ 80
82
+ 81
83
+ 82
84
+ 83
85
+ 84
86
+ 85
87
+ 86
88
+ 87
89
+ 88
90
+ 89
91
+ 90
92
+ 91
93
+ 92
94
+ 93
95
+ 94
96
+ 95
97
+ 96
98
+ 97
99
+ 98
100
+ 99
101
+ 100
102
+ 101
103
+ 102
104
+ 103
105
+ 104
106
+ 105
107
+ 106
108
+ 107
109
+ 108
110
+ 109
111
+ 110
112
+ 111
113
+ 112
114
+ 113
115
+ 114
116
+ 115
117
+ 116
118
+ 117
119
+ 118
120
+ 119
121
+ 120
122
+ 121
123
+ 122
124
+ 123
125
+ 124
126
+ 125
127
+ 126
128
+ 127
129
+ 128
130
+ 129
131
+ 130
132
+ 131
133
+ 132
134
+ 133
135
+ 134
136
+ 135
137
+ 136
138
+ 137
139
+ 138
140
+ 139
141
+ 140
142
+ 141
143
+ 142
144
+ 143
145
+ 144
146
+ 145
147
+ 146
148
+ 147
149
+ 148
150
+ 149
151
+ 150
152
+ 151
153
+ 152
154
+ 153
155
+ 154
156
+ 155
157
+ 156
158
+ 157
159
+ 158
160
+ 159
161
+ 160
162
+ 161
163
+ 162
164
+ 163
165
+ 164
166
+ 165
167
+ 166
168
+ 167
169
+ 168
170
+ 169
171
+ 170
172
+ 171
173
+ 172
174
+ 173
175
+ 174
176
+ 175
177
+ 176
178
+ 177
179
+ 178
180
+ 179
181
+ 180
182
+ 181
183
+ 182
184
+ 183
185
+ 184
186
+ 185
187
+ 186
188
+ 187
189
+ 188
190
+ 189
191
+ 190
192
+ 191
193
+ 192
194
+ 193
195
+ 194
196
+ 195
197
+ 196
198
+ 197
199
+ 198
200
+ 199
201
+ 200
202
+ 201
203
+ 202
204
+ 203
205
+ 204
206
+ 205
207
+ 206
208
+ 207
209
+ 208
210
+ 209
211
+ 210
212
+ 211
213
+ 212
214
+ 213
215
+ 214
216
+ 215
217
+ 216
218
+ 217
219
+ 218
220
+ 219
221
+ 220
222
+ 221
223
+ 222
224
+ 223
225
+ 224
226
+ 225
227
+ 226
228
+ 227
229
+ 228
230
+ 229
231
+ 230
232
+ 231
233
+ 232
234
+ 233
235
+ 234
236
+ 235
237
+ 236
238
+ 237
239
+ 238
240
+ 239
241
+ 240
242
+ 241
243
+ 242
244
+ 243
245
+ 244
246
+ 245
247
+ 246
248
+ 247
249
+ 248
250
+ 249
251
+ 250
252
+ 251
253
+ 252
254
+ 253
255
+ 254
256
+ 255
257
+ 256
258
+ 257
259
+ 258
260
+ 259
261
+ 260
262
+ 261
263
+ 262
264
+ 263
265
+ 264
266
+ 265
267
+ 266
268
+ 267
269
+ 268
270
+ 269
271
+ 270
272
+ 271
273
+ 272
274
+ 273
275
+ 274
276
+ 275
277
+ 276
278
+ 277
279
+ 278
280
+ 279
281
+ 280
282
+ 281
283
+ 282
284
+ 283
285
+ 284
286
+ 285
287
+ 286
288
+ 287
289
+ 288
290
+ 289
291
+ 290
292
+ 291
293
+ 292
294
+ 293
295
+ 294
296
+ 295
297
+ 296
298
+ 297
299
+ 298
300
+ 299
301
+ 300
302
+ 301
303
+ 302
304
+ 303
305
+ 304
306
+ 305
307
+ 306
308
+ 307
309
+ 308
310
+ 309
311
+ 310
312
+ 311
313
+ 312
314
+ 313
315
+ 314
316
+ 315
317
+ 316
318
+ 317
319
+ 318
320
+ 319
321
+ 320
322
+ 321
323
+ 322
324
+ 323
325
+ 324
326
+ 325
327
+ 326
328
+ 327
329
+ 328
330
+ 329
331
+ 330
332
+ 331
333
+ 332
334
+ 333
335
+ 334
336
+ 335
337
+ 336
338
+ 337
339
+ 338
340
+ 339
341
+ 340
342
+ 341
343
+ 342
344
+ 343
345
+ 344
346
+ 345
347
+ 346
348
+ 347
349
+ 348
350
+ 349
351
+ 350
352
+ 351
353
+ 352
354
+ 353
355
+ 354
356
+ 355
357
+ 356
358
+ 357
359
+ 358
360
+ 359
361
+ 360
362
+ 361
363
+ 362
364
+ 363
365
+ 364
366
+ 365
367
+ 366
368
+ 367
369
+ 368
370
+ 369
371
+ 370
372
+ 371
373
+ 372
374
+ 373
375
+ 374
376
+ 375
377
+ 376
378
+ 377
379
+ 378
380
+ 379
381
+ 380
382
+ 381
383
+ 382
384
+ 383
385
+ 384
386
+ 385
387
+ 386
388
+ 387
389
+ 388
390
+ 389
391
+ 390
392
+ 391
393
+ 392
394
+ 393
395
+ 394
396
+ 395
397
+ 396
398
+ 397
399
+ 398
400
+ 399
401
+ 400
402
+ 401
403
+ 402
404
+ 403
405
+ 404
406
+ 405
407
+ 406
408
+ 407
409
+ 408
410
+ 409
411
+ 410
412
+ 411
413
+ 412
414
+ 413
415
+ 414
416
+ 415
417
+ 416
418
+ 417
419
+ 418
420
+ 419
421
+ 420
422
+ 421
423
+ 422
424
+ 423
425
+ 424
426
+ 425
427
+ 426
428
+ 427
429
+ 428
430
+ 429
431
+ 430
432
+ 431
433
+ 432
434
+ 433
435
+ 434
436
+ 435
437
+ 436
438
+ 437
439
+ 438
440
+ 439
441
+ 440
442
+ 441
443
+ 442
444
+ 443
445
+ 444
446
+ 445
447
+ 446
448
+ 447
449
+ 448
450
+ 449
451
+ 450
452
+ 451
453
+ 452
454
+ 453
455
+ 454
456
+ 455
457
+ 456
458
+ 457
459
+ 458
460
+ 459
461
+ 460
462
+ 461
463
+ 462
464
+ 463
465
+ 464
466
+ 465
467
+ 466
468
+ 467
469
+ 468
470
+ 469
471
+ 470
472
+ 471
473
+ 472
474
+ 473
475
+ 474
476
+ 475
477
+ 476
478
+ 477
479
+ 478
480
+ 479
481
+ 480
482
+ 481
483
+ 482
484
+ 483
485
+ 484
486
+ 485
487
+ 486
488
+ 487
489
+ 488
490
+ 489
491
+ 490
492
+ 491
493
+ 492
494
+ 493
495
+ 494
496
+ 495
497
+ 496
498
+ 497
499
+ 498
500
+ 499
@@ -0,0 +1,157 @@
1
+ require './lib/file_monitoring/monitor_path'
2
+ require 'test/unit'
3
+ require 'fileutils'
4
+
5
+ module BBFS
6
+ module FileMonitoring
7
+ module Test
8
+ class TestPathMonitor < ::Test::Unit::TestCase
9
+ # directory where tested files will be placed: __FILE__/time_modification_test
10
+ RESOURCES_DIR = File.expand_path(File.dirname(__FILE__) + '/path_monitor_test')
11
+ MOVE_DIR = '/dir1500' # directory that will be moved
12
+ MOVE_FILE = '/test_file.1000' # file that will be moved
13
+ MOVE_SRC_DIR = RESOURCES_DIR + '/dir1000' # directory where moved entities where placed
14
+ MOVE_DEST_DIR = RESOURCES_DIR # directory where moved entities will be placed
15
+ LOG_PATH = RESOURCES_DIR + '/../log.txt'
16
+
17
+ def setup
18
+ @sizes = [500, 1000, 1500]
19
+ @numb_of_copies = 2
20
+ @numb_entities = @sizes.size * (@numb_of_copies + 1) + @sizes.size
21
+ @test_file_name = 'test_file' # file name format: <test_file_name_prefix>.<size>[.serial_number_if_more_then_1]
22
+ @test_dir_name = 'dir'
23
+ ::FileUtils.rm_rf(RESOURCES_DIR) if (File.exists?(RESOURCES_DIR))
24
+
25
+ # prepare files for testing
26
+ cur_dir = nil; # directory where currently files created in this iteration will be placed
27
+
28
+ @sizes.each do |size|
29
+ file_name = @test_file_name + '.' + size.to_s
30
+
31
+ if (cur_dir == nil)
32
+ cur_dir = String.new(RESOURCES_DIR)
33
+ else
34
+ cur_dir = cur_dir + "/#{@test_dir_name}" + size.to_s
35
+ end
36
+ Dir.mkdir(cur_dir) unless (File.exists?(cur_dir))
37
+ raise "Can't create writable working directory: #{cur_dir}" unless (File.exists?(cur_dir) and File.writable?(cur_dir))
38
+
39
+ file_path = cur_dir + '/' + file_name
40
+ File.open(file_path, 'w') do |file|
41
+ content = Array.new
42
+ size.times do |i|
43
+ content.push(sprintf('%5d ', i))
44
+ end
45
+ file.puts(content)
46
+ end
47
+
48
+ @numb_of_copies.times do |i|
49
+ ::FileUtils.cp(file_path, "#{file_path}.#{i}")
50
+ end
51
+ end
52
+ end
53
+
54
+ def test_monitor
55
+ log = File.open(LOG_PATH, 'w+')
56
+ FileStat.set_log(log)
57
+ test_dir = DirStat.new(RESOURCES_DIR)
58
+
59
+ # Initial run of monitoring -> initializing DirStat object
60
+ # all found object will be set to NEW state
61
+ # no output to the log
62
+ test_dir.monitor
63
+
64
+ # all files will be set to UNCHANGED
65
+ log_prev_pos = log.pos
66
+ log_prev_line = log.lineno
67
+ test_dir.monitor
68
+ sleep(1) # to be sure that data was indeed written
69
+ log.pos= log_prev_pos
70
+ log.each_line do |line|
71
+ assert_equal(true, line.include?(FileStatEnum::UNCHANGED))
72
+ end
73
+ assert_equal(@numb_entities, log.lineno - log_prev_line) # checking that all entities were monitored
74
+
75
+ # move (equivalent to delete and create new) directory with including files to new location
76
+ ::FileUtils.mv MOVE_SRC_DIR + MOVE_DIR, MOVE_DEST_DIR + MOVE_DIR
77
+ log_prev_pos = log.pos
78
+ log_prev_line = log.lineno
79
+ test_dir.monitor
80
+ sleep(1)
81
+ log.pos= log_prev_pos
82
+ log.each_line do |line|
83
+ if (line.include?(MOVE_SRC_DIR + MOVE_DIR))
84
+ assert_equal(true, line.include?(FileStatEnum::NON_EXISTING))
85
+ elsif (line.include?(MOVE_DEST_DIR + MOVE_DIR))
86
+ assert_equal(true, line.include?(FileStatEnum::NEW))
87
+ elsif (line.include?(MOVE_SRC_DIR) or line.include?(MOVE_DEST_DIR))
88
+ assert_not_equal(true, line.include?(FileStatEnum::UNCHANGED))
89
+ assert_equal(true, line.include?(FileStatEnum::CHANGED))
90
+ end
91
+ end
92
+ # old and new containing directories: 2
93
+ # moved directory: 1
94
+ # deleted directory: 1
95
+ # moved files: @numb_of_copies + 1
96
+ assert_equal(5 + @numb_of_copies, log.lineno - log_prev_line) # checking that only MOVE_DIR_SRC, MOVE_DIR_DEST states were changed
97
+
98
+ # no changes:
99
+ # changed and new files moved to UNCHANGED
100
+ log_prev_pos = log.pos
101
+ log_prev_line = log.lineno
102
+ test_dir.monitor
103
+ sleep(1)
104
+ log.pos= log_prev_pos
105
+ log.each_line do |line|
106
+ assert_equal(true, line.include?(FileStatEnum::UNCHANGED))
107
+ end
108
+ # old and new containing directories: 2
109
+ # moved directory: 1
110
+ # moved files: @numb_of_copies + 1
111
+ assert_equal(4 + @numb_of_copies, log.lineno - log_prev_line)
112
+
113
+ # move (equivalent to delete and create new) file
114
+ log_prev_pos = log.pos
115
+ log_prev_line = log.lineno
116
+ ::FileUtils.mv MOVE_SRC_DIR + MOVE_FILE, MOVE_DEST_DIR + MOVE_FILE
117
+ test_dir.monitor
118
+ sleep(1)
119
+ log.pos= log_prev_pos
120
+ log.each_line do |line|
121
+ if (line.include?MOVE_SRC_DIR + MOVE_FILE)
122
+ assert_equal(true, line.include?(FileStatEnum::NON_EXISTING))
123
+ elsif (line.include?MOVE_DEST_DIR + MOVE_FILE)
124
+ assert_equal(true, line.include?(FileStatEnum::NEW))
125
+ elsif (line.include?MOVE_SRC_DIR or line.include?MOVE_DEST_DIR)
126
+ assert_equal(true, line.include?(FileStatEnum::CHANGED))
127
+ end
128
+ end
129
+ # old and new containing directories: 2
130
+ # removed file: 1
131
+ # new file: 1
132
+ assert_equal(4, log.lineno - log_prev_line)
133
+
134
+ # all files were moved to UNCHANGED
135
+ test_dir.monitor
136
+
137
+ # check that all entities moved to stable
138
+ log_prev_pos = log.pos
139
+ log_prev_line = log.lineno
140
+ (test_dir.stable_state + 1).times do
141
+ test_dir.monitor
142
+ end
143
+ sleep(1)
144
+ log.pos= log_prev_pos
145
+ log.each_line do |line|
146
+ assert_equal(true, line.include?(FileStatEnum::STABLE))
147
+ end
148
+ assert_equal(@numb_entities, log.lineno - log_prev_line)
149
+
150
+ log.close
151
+ end
152
+ end
153
+
154
+
155
+ end
156
+ end
157
+ end