Exemplo n.º 1
0
 def test_AddBox_set_size_doesnot_affect_mod_or_multiplier(self):
     self.AB._mod = 100
     self.AB._multiplier = 50
     self.AB.set_size(2)
     self.assertEqual(self.AB._mod, 100)
     self.assertEqual(self.AB._multiplier, 50)
     self.assertEqual(self.AB._die, dt.StrongDie(dt.ModDie(2, 100), 50))
Exemplo n.º 2
0
 def test_check_data_all_die_types_pass(self):
     table = dt.DiceTable()
     table.add_die(1, dt.Die(4))
     table.add_die(1, dt.ModDie(4, 2))
     table.add_die(1, dt.WeightedDie({1: 2}))
     table.add_die(1, dt.ModWeightedDie({1: 2}, 3))
     table.add_die(1, dt.StrongDie(dt.Die(3), 3))
     obj = create_plot_object(table)
     self.assertEqual(fh.check_data(obj), 'ok')
Exemplo n.º 3
0
def make_die(size, modifier, multiplier, dictionary):
    '''makes the die into a new die. IMPORTANT!! dictionary supercedes size
    so if size is 6 and dictionary is {1:1, 2:4}, then die is made according
    to dictionary.  size-int>0, modifier-int, multiplier-int>=0.'''
    dice = {'die':dt.Die(size), 'moddie': dt.ModDie(size, modifier)}
    die_key = 'die'
    if dictionary:
        if sum(dictionary.values()) != 0:
            for value in dictionary.values():
                if value != 1:
                    die_key = 'weighteddie'
                    dice['weighteddie'] = dt.WeightedDie(dictionary)
                    dice['modweighteddie'] = dt.ModWeightedDie(dictionary,
                                                               modifier)
                    break
    if modifier:
        die_key = 'mod' + die_key

    if multiplier > 1:
        return dt.StrongDie(dice[die_key], multiplier)
    else:
        return dice[die_key]
Exemplo n.º 4
0
def make_die(size, modifier, multiplier, dictionary):
    """
    if is_dictionary_for_weigted_die, then dictionary supercedes size

    :return: Die, ModDie, WeightedDie, ModWeightedDie or StrongDie
    """
    if not dictionary:
        dictionary = {1: 0}
    dice = {
        'Die': dt.Die(size),
        'ModDie': dt.ModDie(size, modifier),
        'WeightedDie': dt.WeightedDie(dictionary),
        'ModWeightedDie': dt.ModWeightedDie(dictionary, modifier)
    }
    die_key = 'Die'
    if is_dictionary_for_weighted_die(dictionary):
        die_key = 'WeightedDie'
    if modifier:
        die_key = 'Mod' + die_key

    if multiplier > 1:
        return dt.StrongDie(dice[die_key], multiplier)
    else:
        return dice[die_key]
Exemplo n.º 5
0
 def test_make_die_input_die__moddie(self):
     self.assertEqual(mvm.make_die(3, 1, 0, {1: 1, 2: 1, 3: 1}),
                      dt.ModDie(3, 1))
Exemplo n.º 6
0
 def test_get_die_label_non_zero(self):
     self.assertEqual(mvm.get_die_label(dt.ModDie(1, 3), 5), '5D1+15')
Exemplo n.º 7
0
 def test_get_add_choices_mid_size(self):
     self.assertEqual(mvm.get_add_choices(dt.ModDie(25, 10)), [1, 5, 10, 50])
Exemplo n.º 8
0
 def test_get_die_roll_details_with_negative_number_as_longest(self):
     expected_text = ('(D3-2)X10 rolls:\n' +
                      '  -10 with frequency: 1\n' +
                      '    0 with frequency: 1\n' +
                      '   10 with frequency: 1')
     self.assertEqual(expected_text, mvm.get_die_roll_details(dt.StrongDie(dt.ModDie(3, -2), 10)))
Exemplo n.º 9
0
 def test_get_graphs_x_range(self):
     self.DTM.request_add(1, dt.ModDie(1, -101))
     self.ST.save_new(self.DTM.get_obj_to_save())
     self.DTM.request_add(1, dt.ModDie(1, 199))
     self.ST.save_new(self.DTM.get_obj_to_save())
     self.assertEqual(mvm.get_graphs(self.ST.get_all())[0], (-100, 100))
Exemplo n.º 10
0
 def test_history_manager_get_graphs_x_range(self):
     self.TM.request_add(1, dt.ModDie(1, -101))
     self.HM.add_plot_obj(self.TM.request_plot_obj(True))
     self.TM.request_add(1, dt.ModDie(1, 199))
     self.HM.add_plot_obj(self.TM.request_plot_obj(True))
     self.assertEqual(self.HM.get_graphs()[0], (-100, 100))