3176 def testModifier(self):
3178 p = Process(
"test",m1)
3179 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1))
3182 m1.toModify(p.a,_mod_fred)
3183 self.assertEqual(p.a.fred.value(),2)
3184 p.b = EDAnalyzer(
"YourAnalyzer", wilma = int32(1))
3185 m1.toModify(p.b, wilma = 2)
3186 self.assertEqual(p.b.wilma.value(),2)
3187 self.assertTrue(p.isUsingModifier(m1))
3191 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1))
3192 m1.toModify(p.a,_mod_fred)
3193 p.b = EDAnalyzer(
"YourAnalyzer", wilma = int32(1))
3194 m1.toModify(p.b, wilma = 2)
3195 self.assertEqual(p.a.fred.value(),1)
3196 self.assertEqual(p.b.wilma.value(),1)
3197 self.assertEqual(p.isUsingModifier(m1),
False)
3200 p = Process(
"test",m1)
3201 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1), wilma = int32(1))
3202 m1.toModify(p.a, fred = int32(2))
3203 p.b = p.a.clone(wilma = int32(3))
3204 self.assertEqual(p.a.fred.value(),2)
3205 self.assertEqual(p.a.wilma.value(),1)
3206 self.assertEqual(p.b.fred.value(),2)
3207 self.assertEqual(p.b.wilma.value(),3)
3210 p = Process(
"test",m1)
3211 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1), wilma = int32(1), fintstones = PSet(fred = int32(1)))
3212 m1.toModify(p.a, fred =
None, fintstones = dict(fred =
None))
3213 self.assertEqual(hasattr(p.a,
"fred"),
False)
3214 self.assertEqual(hasattr(p.a.fintstones,
"fred"),
False)
3215 self.assertEqual(p.a.wilma.value(),1)
3218 p = Process(
"test",m1)
3219 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1))
3220 m1.toModify(p.a, wilma = int32(2))
3221 self.assertEqual(p.a.fred.value(), 1)
3222 self.assertEqual(p.a.wilma.value(),2)
3225 p = Process(
"test",m1)
3226 p.a = EDAnalyzer(
"MyAnalyzer", flintstones = PSet(fred = int32(1), wilma = int32(1)))
3227 m1.toModify(p.a, flintstones = dict(fred = int32(2)))
3228 self.assertEqual(p.a.flintstones.fred.value(),2)
3229 self.assertEqual(p.a.flintstones.wilma.value(),1)
3232 p = Process(
"test",m1)
3233 p.a = EDAnalyzer(
"MyAnalyzer", flintstones = PSet(fred = PSet(wilma = int32(1))))
3234 self.assertRaises(KeyError,
lambda: m1.toModify(p.a, flintstones = dict(imnothere = dict(wilma=2))))
3235 self.assertRaises(KeyError,
lambda: m1.toModify(p.a, foo = 1))
3238 p = Process(
"test",m1)
3239 p.a = EDAnalyzer(
"MyAnalyzer", flintstones =
VPSet(PSet(fred = int32(1)), PSet(wilma = int32(1))))
3240 m1.toModify(p.a, flintstones = {1:dict(wilma = int32(2))})
3241 self.assertEqual(p.a.flintstones[0].fred.value(),1)
3242 self.assertEqual(p.a.flintstones[1].wilma.value(),2)
3245 p = Process(
"test",m1)
3246 p.a = EDAnalyzer(
"MyAnalyzer", fred = vuint32(1,2,3))
3247 m1.toModify(p.a, fred = {1:7})
3248 self.assertEqual(p.a.fred[0],1)
3249 self.assertEqual(p.a.fred[1],7)
3250 self.assertEqual(p.a.fred[2],3)
3253 p = Process(
"test",m1)
3254 p.a = EDAnalyzer(
"MyAnalyzer", fred = vuint32(1,2,3))
3256 try: m1.toModify(p.a, fred = {5:7})
3257 except IndexError
as e: raised =
True
3258 self.assertEqual(raised,
True)
3261 p = Process(
"test",m1)
3262 p.a = EDAnalyzer(
"MyAnalyzer", flintstones =
VPSet(PSet(fred = int32(1)), PSet(wilma = int32(1))))
3264 try: m1.toModify(p.a, flintstones = dict(bogus = int32(37)))
3265 except TypeError
as e: raised =
True
3266 self.assertEqual(raised,
True)
3270 class ProcModifierMod(
object):
3271 def __init__(self,modifier,func):
3272 self.proc_mod_ = modifier.makeProcessModifier(func)
3275 self.a = EDAnalyzer(
"Dummy")
3276 testMod = DummyMod()
3278 self.assertTrue(hasattr(p,
"a"))
3280 p = Process(
"test",m1)
3281 testProcMod = ProcModifierMod(m1,_rem_a)
3283 p.extend(testProcMod)
3284 self.assertTrue(
not hasattr(p,
"a"))
3287 mc = ModifierChain(m1)
3288 p = Process(
"test",mc)
3289 self.assertTrue(p.isUsingModifier(m1))
3290 self.assertTrue(p.isUsingModifier(mc))
3291 testMod = DummyMod()
3292 p.b = EDAnalyzer(
"Dummy2", fred = int32(1))
3293 m1.toModify(p.b, fred = int32(3))
3295 testProcMod = ProcModifierMod(m1,_rem_a)
3296 p.extend(testProcMod)
3297 self.assertTrue(
not hasattr(p,
"a"))
3298 self.assertEqual(p.b.fred.value(),3)
3302 mc = ModifierChain(m1,m2)
3303 mclone = mc.copyAndExclude([m2])
3304 self.assertTrue(
not mclone._isOrContains(m2))
3305 self.assertTrue(mclone._isOrContains(m1))
3307 mc2 = ModifierChain(mc,m3)
3308 mclone = mc2.copyAndExclude([m2])
3309 self.assertTrue(
not mclone._isOrContains(m2))
3310 self.assertTrue(mclone._isOrContains(m1))
3311 self.assertTrue(mclone._isOrContains(m3))
3315 p = Process(
"test",m1)
3316 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1), wilma = int32(1))
3317 (m1 & m2).toModify(p.a, fred = int32(2))
3318 self.assertRaises(TypeError,
lambda: (m1 & m2).toModify(p.a, 1, wilma=2))
3319 self.assertEqual(p.a.fred, 1)
3322 p = Process(
"test",m1,m2)
3323 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1), wilma = int32(1))
3324 (m1 & m2).toModify(p.a, fred = int32(2))
3325 self.assertEqual(p.a.fred, 2)
3329 p = Process(
"test",m1,m2,m3)
3330 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1), wilma = int32(1))
3331 (m1 & m2 & m3).toModify(p.a, fred = int32(2))
3332 self.assertEqual(p.a.fred, 2)
3333 (m1 & (m2 & m3)).toModify(p.a, fred = int32(3))
3334 self.assertEqual(p.a.fred, 3)
3335 ((m1 & m2) & m3).toModify(p.a, fred = int32(4))
3336 self.assertEqual(p.a.fred, 4)
3340 p = Process(
"test", m1)
3341 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1), wilma = int32(1))
3342 (~m1).toModify(p.a, fred=2)
3343 self.assertEqual(p.a.fred, 1)
3344 (~m2).toModify(p.a, wilma=2)
3345 self.assertEqual(p.a.wilma, 2)
3346 self.assertRaises(TypeError,
lambda: (~m1).toModify(p.a, 1, wilma=2))
3347 self.assertRaises(TypeError,
lambda: (~m2).toModify(p.a, 1, wilma=2))
3352 p = Process(
"test", m1)
3353 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1), wilma = int32(1))
3354 (m1 | m2).toModify(p.a, fred=2)
3355 self.assertEqual(p.a.fred, 2)
3356 (m1 | m2 | m3).toModify(p.a, fred=3)
3357 self.assertEqual(p.a.fred, 3)
3358 (m3 | m2 | m1).toModify(p.a, fred=4)
3359 self.assertEqual(p.a.fred, 4)
3360 ((m1 | m2) | m3).toModify(p.a, fred=5)
3361 self.assertEqual(p.a.fred, 5)
3362 (m1 | (m2 | m3)).toModify(p.a, fred=6)
3363 self.assertEqual(p.a.fred, 6)
3364 (m2 | m3).toModify(p.a, fred=7)
3365 self.assertEqual(p.a.fred, 6)
3366 self.assertRaises(TypeError,
lambda: (m1 | m2).toModify(p.a, 1, wilma=2))
3367 self.assertRaises(TypeError,
lambda: (m2 | m3).toModify(p.a, 1, wilma=2))
3373 p = Process(
"test", m1, m2)
3374 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1), wilma = int32(1))
3375 (m1 & ~m2).toModify(p.a, fred=2)
3376 self.assertEqual(p.a.fred, 1)
3377 (m1 & ~m3).toModify(p.a, fred=2)
3378 self.assertEqual(p.a.fred, 2)
3379 (m1 | ~m2).toModify(p.a, fred=3)
3380 self.assertEqual(p.a.fred, 3)
3381 (~m1 | ~m2).toModify(p.a, fred=4)
3382 self.assertEqual(p.a.fred, 3)
3383 (~m3 & ~m4).toModify(p.a, fred=4)
3384 self.assertEqual(p.a.fred, 4)
3385 ((m1 & m3) | ~m4).toModify(p.a, fred=5)
3386 self.assertEqual(p.a.fred, 5)
3389 p = Process(
"test",m1)
3390 p.a =EDAnalyzer(
"MyAnalyzer", fred = int32(1))
3391 m1.toReplaceWith(p.a, EDAnalyzer(
"YourAnalyzer", wilma = int32(3)))
3392 self.assertRaises(TypeError,
lambda: m1.toReplaceWith(p.a, EDProducer(
"YourProducer")))
3393 p.b =EDAnalyzer(
"BAn")
3394 p.c =EDProducer(
"c")
3395 p.d =EDProducer(
"d")
3399 m1.toReplaceWith(p.s,
Sequence(p.a+p.b, p.td))
3400 self.assertEqual(p.a.wilma.value(),3)
3401 self.assertEqual(p.a.type_(),
"YourAnalyzer")
3402 self.assertEqual(hasattr(p,
"fred"),
False)
3403 self.assertTrue(p.s.dumpPython() ==
"cms.Sequence(process.a+process.b, process.td)\n")
3404 p.e =EDProducer(
"e")
3405 m1.toReplaceWith(p.td, Task(p.e))
3406 self.assertTrue(p.td._collection ==
OrderedSet([p.e]))
3410 p.a =EDAnalyzer(
"MyAnalyzer", fred = int32(1))
3411 m1.toReplaceWith(p.a, EDAnalyzer(
"YourAnalyzer", wilma = int32(3)))
3412 self.assertEqual(p.a.type_(),
"MyAnalyzer")
3418 p = Process(
"test", m1, m2)
3419 p.a = EDAnalyzer(
"MyAnalyzer", fred = int32(1), wilma = int32(1))
3420 self.assertRaises(TypeError,
lambda: (m1 & m2).toReplaceWith(p.a, EDProducer(
"YourProducer")))
3421 self.assertRaises(TypeError,
lambda: (m3 & m4).toReplaceWith(p.a, EDProducer(
"YourProducer")))
3422 self.assertRaises(TypeError,
lambda: (~m3).toReplaceWith(p.a, EDProducer(
"YourProducer")))
3423 self.assertRaises(TypeError,
lambda: (~m1).toReplaceWith(p.a, EDProducer(
"YourProducer")))
3424 self.assertRaises(TypeError,
lambda: (m1 | m3).toReplaceWith(p.a, EDProducer(
"YourProducer")))
3425 self.assertRaises(TypeError,
lambda: (m3 | m4).toReplaceWith(p.a, EDProducer(
"YourProducer")))
3426 (m1 & m2).toReplaceWith(p.a, EDAnalyzer(
"YourAnalyzer1"))
3427 self.assertEqual(p.a.type_(),
"YourAnalyzer1")
3428 (m1 & m3).toReplaceWith(p.a, EDAnalyzer(
"YourAnalyzer2"))
3429 self.assertEqual(p.a.type_(),
"YourAnalyzer1")
3430 (~m1).toReplaceWith(p.a, EDAnalyzer(
"YourAnalyzer2"))
3431 self.assertEqual(p.a.type_(),
"YourAnalyzer1")
3432 (~m3).toReplaceWith(p.a, EDAnalyzer(
"YourAnalyzer2"))
3433 self.assertEqual(p.a.type_(),
"YourAnalyzer2")
3434 (m1 | m3).toReplaceWith(p.a, EDAnalyzer(
"YourAnalyzer3"))
3435 self.assertEqual(p.a.type_(),
"YourAnalyzer3")
3436 (m3 | m4).toReplaceWith(p.a, EDAnalyzer(
"YourAnalyzer4"))
3437 self.assertEqual(p.a.type_(),
"YourAnalyzer3")
3440 a = EDAlias(foo2 =
VPSet(PSet(type =
string(
"Foo2"))))
3444 m.toModify(a, foo2 = {0: dict(type =
"Foo3")})
3445 self.assertEqual(a.foo2[0].type,
"Foo3")
3447 m.toModify(a, foo4 =
VPSet(PSet(type =
string(
"Foo4"))))
3448 self.assertEqual(a.foo2[0].type,
"Foo3")
3449 self.assertEqual(a.foo4[0].type,
"Foo4")
3451 m.toModify(a, foo2 =
None)
3452 self.assertFalse(hasattr(a,
"foo2"))
3453 self.assertEqual(a.foo4[0].type,
"Foo4")
3455 m.toReplaceWith(a, EDAlias(bar =
VPSet(PSet(type =
string(
"Bar")))))
3456 self.assertFalse(hasattr(a,
"foo2"))
3457 self.assertFalse(hasattr(a,
"foo4"))
3458 self.assertTrue(hasattr(a,
"bar"))
3459 self.assertEqual(a.bar[0].type,
"Bar")
3462 sp = SwitchProducerTest(test1 = EDProducer(
"Foo",
3464 b = PSet(c = int32(2))),
3465 test2 = EDProducer(
"Bar",
3467 bb = PSet(cc = int32(12))))
3472 test1 = dict(a = 4, b = dict(c =
None)),
3473 test2 = dict(aa = 15, bb = dict(cc = 45, dd =
string(
"foo"))))
3474 self.assertEqual(sp.test1.a.value(), 4)
3475 self.assertEqual(sp.test1.b.hasParameter(
"c"),
False)
3476 self.assertEqual(sp.test2.aa.value(), 15)
3477 self.assertEqual(sp.test2.bb.cc.value(), 45)
3478 self.assertEqual(sp.test2.bb.dd.value(),
"foo")
3480 m.toReplaceWith(sp.test1, EDProducer(
"Fred", x = int32(42)))
3481 self.assertEqual(sp.test1.type_(),
"Fred")
3482 self.assertEqual(sp.test1.x.value(), 42)
3483 self.assertRaises(TypeError,
lambda: m.toReplaceWith(sp.test1, EDAnalyzer(
"Foo")))
3485 m.toModify(sp, test2 = EDProducer(
"Xyzzy", x = int32(24)))
3486 self.assertEqual(sp.test2.type_(),
"Xyzzy")
3487 self.assertEqual(sp.test2.x.value(), 24)
3488 self.assertRaises(TypeError,
lambda: m.toModify(sp, test2 = EDAnalyzer(
"Foo")))
3490 m.toModify(sp, test3 = EDProducer(
"Wilma", y = int32(24)))
3491 self.assertEqual(sp.test3.type_(),
"Wilma")
3492 self.assertEqual(sp.test3.y.value(), 24)
3493 self.assertRaises(TypeError,
lambda: m.toModify(sp, test4 = EDAnalyzer(
"Foo")))
3495 m.toModify(sp, test2 =
None)
3496 self.assertEqual(hasattr(sp,
"test2"),
False)
3498 m.toModify(sp, test2 = EDAlias(foo =
VPSet(PSet(type =
string(
"int")))))
3499 self.assertTrue(hasattr(sp.test2,
"foo"))
3501 m.toReplaceWith(sp.test2, EDAlias(bar =
VPSet(PSet(type =
string(
"int")))))
3502 self.assertTrue(hasattr(sp.test2,
"bar"))
3504 m.toModify(sp, test2 = EDAlias(xyzzy =
VPSet(PSet(type =
string(
"int")))))
3505 self.assertTrue(hasattr(sp.test2,
"xyzzy"))
3507 self.assertRaises(TypeError,
lambda: m.toReplaceWith(sp.test2, EDProducer(
"Foo")))
3508 m.toModify(sp, test2 = EDProducer(
"Foo"))