#!/usr/bin/env python """ Script to rename specific model entries in the database. WARNING: This directly modifies database records and should ONLY be used in test environments. """ import argparse import logging from database.models import Model from database.utils import session_scope from sqlalchemy import and_ # Configure logging logging.basicConfig(  level=logging.INFO,  format='%(asctime)s - %(levelname)s - %(message)s' ) def rename_model(old_name, new_name, dry_run=True):  """  Rename a model in the database by updating its weights_location.  Args:  old_name: The current weights_location to find  new_name: The new weights_location to replace it with  dry_run: If True, don't apply changes, just print what would be done  Returns:  Number of records modified  """  with session_scope() as session:  # Find models with exact matching weights_location  models = session.query(Model).filter(  Model.weights_location == old_name  ).all()  if not models:  logging.warning(f"No models found with exact weights_location '{old_name}'")  return 0  logging.info(f"Found {len(models)} models with weights_location '{old_name}'")  # Log details of matched models  for i, model in enumerate(models):  logging.info(f"Model {i+1}:")  logging.info(f" ID: {model.id}")  logging.info(f" Weights Location: {model.weights_location}")  logging.info(f" Creation Time: {model.creation_time}")  # Get dataset information if available  if model.dataset_id:  logging.info(f" Dataset ID: {model.dataset_id}")  # Preview the change  logging.info(f" CHANGE: {model.weights_location} -> {new_name}")  # Apply the changes if not a dry run  if not dry_run:  for model in models:  model.weights_location = new_name  # Commit the transaction  session.commit()  logging.info(f"Renamed {len(models)} models from '{old_name}' to '{new_name}'")  else:  logging.info(f"DRY RUN: Would rename {len(models)} models from '{old_name}' to '{new_name}'")  return len(models) def main():  parser = argparse.ArgumentParser(description='Rename specific models in the database')  parser.add_argument('--dry-run', action='store_true',  help='Print changes without modifying the database')  args = parser.parse_args()  # Define the renames to perform  renames = [  ("/s1-main", "/s1"),  ("/mo-main", "/mo")  ]  total_modified = 0  logging.info(f"{'DRY RUN: ' if args.dry_run else ''}Starting model rename operations...")  # Perform each rename  for old_name, new_name in renames:  count = rename_model(old_name, new_name, args.dry_run)  total_modified += count  logging.info(f"{'DRY RUN: ' if args.dry_run else ''}Completed. {total_modified} records would be modified.")  if args.dry_run:  logging.info("This was a dry run. No changes were made to the database.")  logging.info("To apply changes, run the script without the --dry-run flag.") if __name__ == '__main__':  main()