[Kimchi-devel] [PATCH] [Wok] Upgrade objectstore schema.

Ramon Medeiros ramonn at linux.vnet.ibm.com
Mon Dec 14 18:50:14 UTC 2015


Reviewed-By: Ramon Medeiros <ramonn at br.ibm.com>

On 12/14/2015 03:05 PM, pvital at linux.vnet.ibm.com wrote:
> From: Paulo Vital <pvital at linux.vnet.ibm.com>
>
> With the new structure of the objectstore changed in Wok 2.0.0, the schema of
> the objectstore file (when used by any plugin) needs to be checked and, if
> necessary, updated to reflect the new structure.
>
> This patch adds to utils.py file some common methods to support the operations
> in the plugin's objectstore files. These methods were moved from Kimchi plugin
> since they will be used by other plugins to do the same.
>
> Signed-off-by: Paulo Vital <pvital at linux.vnet.ibm.com>
> ---
>   src/wok/utils.py | 45 +++++++++++++++++++++++++++++++++++++++++++++
>   1 file changed, 45 insertions(+)
>
> diff --git a/src/wok/utils.py b/src/wok/utils.py
> index 8c8973a..997adf3 100644
> --- a/src/wok/utils.py
> +++ b/src/wok/utils.py
> @@ -26,6 +26,7 @@ import os
>   import psutil
>   import pwd
>   import re
> +import sqlite3
>   import subprocess
>   import traceback
>   import xml.etree.ElementTree as ET
> @@ -504,3 +505,47 @@ def convert_data_size(value, from_unit, to_unit='B'):
>                       break
>
>       return ret
> +
> +
> +def get_objectstore_fields(objstore=None):
> +    """
> +        Return a list with all fields from the objectstore.
> +    """
> +    if objstore is None:
> +        wok_log.error("No objectstore set up.")
> +        return None
> +    conn = sqlite3.connect(objstore, timeout=10)
> +    cursor = conn.cursor()
> +    schema_fields = []
> +    sql = "PRAGMA table_info('objects')"
> +    cursor.execute(sql)
> +    for row in cursor.fetchall():
> +        schema_fields.append(row[1])
> +    return schema_fields
> +
> +
> +def upgrade_objectstore_schema(objstore=None, field=None):
> +    """
> +        Add a new column (of type TEXT) in the objectstore schema.
> +    """
> +    if (field or objstore) is None:
> +        wok_log.error("Cannot upgrade objectstore schema.")
> +        return False
> +
> +    if field in get_objectstore_fields(objstore):
> +        # field already exists in objectstore schema. Nothing to do.
> +        return False
> +    try:
> +        conn = sqlite3.connect(objstore, timeout=10)
> +        cursor = conn.cursor()
> +        sql = "ALTER TABLE objects ADD COLUMN %s TEXT" % field
> +        cursor.execute(sql)
> +        wok_log.info("Objectstore schema sucessfully upgraded: %s" % objstore)
> +        conn.close()
> +    except sqlite3.Error, e:
> +        if conn:
> +            conn.rollback()
> +            conn.close()
> +        wok_log.error("Cannot upgrade objectstore schema: %s" % e.args[0])
> +        return False
> +    return True
> --
> 2.5.0
>
> _______________________________________________
> Kimchi-devel mailing list
> Kimchi-devel at ovirt.org
> http://lists.ovirt.org/mailman/listinfo/kimchi-devel
>

-- 

Ramon Nunes Medeiros
Kimchi Developer
Linux Technology Center Brazil
IBM Systems & Technology Group
Phone : +55 19 2132 7878
ramonn at br.ibm.com




More information about the Kimchi-devel mailing list