Code Coverage

Cobertura Coverage Report > osm_policy_module.migrations >

001_initial.py

Trend

File Coverage summary

NameClassesLinesConditionals
001_initial.py
0%
0/1
0%
0/50
100%
0/0

Coverage Breakdown by Class

NameLinesConditionals
001_initial.py
0%
0/50
N/A

Source

osm_policy_module/migrations/001_initial.py
1 # -*- coding: utf-8 -*-
2
3 # Copyright 2018 Whitestack, LLC
4 # *************************************************************
5
6 # This file is part of OSM Monitoring module
7 # All Rights Reserved to Whitestack, LLC
8
9 # Licensed under the Apache License, Version 2.0 (the "License"); you may
10 # not use this file except in compliance with the License. You may obtain
11 # a copy of the License at
12
13 #         http://www.apache.org/licenses/LICENSE-2.0
14
15 # Unless required by applicable law or agreed to in writing, software
16 # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
17 # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
18 # License for the specific language governing permissions and limitations
19 # under the License.
20
21 # For those usages not covered by the Apache License, Version 2.0 please
22 # contact: bdiaz@whitestack.com or glavado@whitestack.com
23 ##
24 0 """Peewee migrations -- 001_initial.py.
25
26 Some examples (model - class or model name)::
27
28     > Model = migrator.orm['model_name']            # Return model in current state by name
29
30     > migrator.sql(sql)                             # Run custom SQL
31     > migrator.python(func, *args, **kwargs)        # Run python code
32     > migrator.create_model(Model)                  # Create a model (could be used as decorator)
33     > migrator.remove_model(model, cascade=True)    # Remove a model
34     > migrator.add_fields(model, **fields)          # Add fields to a model
35     > migrator.change_fields(model, **fields)       # Change fields
36     > migrator.remove_fields(model, *field_names, cascade=True)
37     > migrator.rename_field(model, old_field_name, new_field_name)
38     > migrator.rename_table(model, new_table_name)
39     > migrator.add_index(model, *col_names, unique=False)
40     > migrator.drop_index(model, *col_names)
41     > migrator.add_not_null(model, *field_names)
42     > migrator.drop_not_null(model, *field_names)
43     > migrator.add_default(model, field_name, default)
44
45 """
46
47 0 import peewee as pw
48
49 0 SQL = pw.SQL
50
51
52 0 def migrate(migrator, database, fake=False, **kwargs):
53     """Write your migrations here."""
54
55 0     @migrator.create_model
56 0     class BaseModel(pw.Model):
57 0         id = pw.AutoField()
58
59 0         class Meta:
60 0             table_name = "basemodel"
61
62 0     @migrator.create_model
63 0     class ScalingGroup(pw.Model):
64 0         id = pw.AutoField()
65 0         nsr_id = pw.CharField(max_length=255)
66 0         vnf_member_index = pw.IntegerField()
67 0         name = pw.CharField(max_length=255)
68 0         content = pw.TextField()
69
70 0         class Meta:
71 0             table_name = "scalinggroup"
72
73 0     @migrator.create_model
74 0     class ScalingPolicy(pw.Model):
75 0         id = pw.AutoField()
76 0         name = pw.CharField(max_length=255)
77 0         cooldown_time = pw.IntegerField()
78 0         last_scale = pw.DateTimeField()
79 0         scaling_group = pw.ForeignKeyField(
80             backref="scaling_policies",
81             column_name="scaling_group_id",
82             field="id",
83             model=migrator.orm["scalinggroup"],
84             on_delete="CASCADE",
85         )
86
87 0         class Meta:
88 0             table_name = "scalingpolicy"
89
90 0     @migrator.create_model
91 0     class ScalingCriteria(pw.Model):
92 0         id = pw.AutoField()
93 0         name = pw.CharField(max_length=255)
94 0         scaling_policy = pw.ForeignKeyField(
95             backref="scaling_criterias",
96             column_name="scaling_policy_id",
97             field="id",
98             model=migrator.orm["scalingpolicy"],
99             on_delete="CASCADE",
100         )
101
102 0         class Meta:
103 0             table_name = "scalingcriteria"
104
105 0     @migrator.create_model
106 0     class ScalingAlarm(pw.Model):
107 0         id = pw.AutoField()
108 0         alarm_uuid = pw.CharField(max_length=255, unique=True)
109 0         action = pw.CharField(max_length=255)
110 0         vnf_member_index = pw.IntegerField()
111 0         vdu_name = pw.CharField(max_length=255)
112 0         scaling_criteria = pw.ForeignKeyField(
113             backref="scaling_alarms",
114             column_name="scaling_criteria_id",
115             field="id",
116             model=migrator.orm["scalingcriteria"],
117             on_delete="CASCADE",
118         )
119
120 0         class Meta:
121 0             table_name = "scalingalarm"
122
123
124 0 def rollback(migrator, database, fake=False, **kwargs):
125     """Write your rollback migrations here."""
126
127 0     migrator.remove_model("scalingalarm")
128
129 0     migrator.remove_model("scalingcriteria")
130
131 0     migrator.remove_model("scalingpolicy")
132
133 0     migrator.remove_model("scalinggroup")
134
135 0     migrator.remove_model("basemodel")