# Sanity check the database
# Copyright (C) 2000 James Troup <james@nocrew.org>
-# $Id: tea,v 1.2 2001-01-10 06:00:12 troup Exp $
+# $Id: tea,v 1.5 2001-02-04 04:27:58 troup Exp $
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
################################################################################
-import pg, sys, os
+import pg, sys, os, string, stat
import utils, db_access
import apt_pkg;
Cnf = None;
projectB = None;
+db_files = {};
+waste = 0.0;
+excluded = {};
+
+def process_dir (arg, dirname, filenames):
+ global waste, db_files, excluded;
+
+ if string.find(dirname, '/disks-') != -1 or string.find(dirname, 'upgrade-') != -1:
+ return;
+ # hack; can't handle .changes files
+ if string.find(dirname, 'proposed-updates') != -1:
+ return;
+ for name in filenames:
+ filename = os.path.abspath(dirname+'/'+name);
+ filename = string.replace(filename, 'potato-proposed-updates', 'proposed-updates');
+ if os.path.isfile(filename) and not os.path.islink(filename) and not db_files.has_key(filename) and not excluded.has_key(filename):
+ waste = waste + os.stat(filename)[stat.ST_SIZE];
+ print filename
+################################################################################
+
+def check_files():
+
+ print "Building list of Database files...";
+
+ q = projectB.query("SELECT l.path, f.filename FROM files f, location l WHERE f.location = l.id")
+ ql = q.getresult();
+
+ db_files = {};
+ for i in ql:
+ filename = os.path.abspath(i[0] + i[1]);
+ db_files[filename] = "";
+ if os.access(filename, os.R_OK) == 0:
+ sys.stderr.write("W: '%s' doesn't exist.\n" % (filename));
+
+ file = utils.open_file(Cnf["Dir::OverrideDir"]+'override.unreferenced','r');
+ for filename in file.readlines():
+ filename = filename[:-1];
+ excluded[filename] = "";
+
+ print "Checking against existent files...";
+
+ os.path.walk(Cnf["Dir::RootDir"]+'dists/', process_dir, None);
+
+ print
+ print "%s wasted..." % (utils.size_type(waste));
+
+################################################################################
+
+def check_dscs():
+ count = 0;
+ suite = 'unstable';
+ for component in Cnf.SubTree("Component").List():
+ if component == "mixed":
+ continue;
+ component = string.lower(component);
+ list_filename = '%s%s_%s_source.list' % (Cnf["Dir::ListsDir"], suite, component);
+ list_file = utils.open_file(list_filename, 'r');
+ for line in list_file.readlines():
+ file = line[:-1];
+ try:
+ utils.parse_changes(file, 1);
+ except utils.invalid_dsc_format_exc, line:
+ sys.stderr.write("E: syntax error in .dsc file '%s', line %s.\n" % (file, line));
+ count = count + 1;
+
+ if count:
+ sys.stderr.write("Found %s invalid .dsc files.\n" % (count));
+
+def check_override():
+ for suite in [ "stable", "unstable" ]:
+ print suite
+ print "-------------"
+ print
+ suite_id = db_access.get_suite_id(suite);
+ q = projectB.query("""
+SELECT DISTINCT b.package FROM binaries b, bin_associations ba
+ WHERE b.id = ba.bin AND ba.suite = %s AND NOT EXISTS
+ (SELECT * FROM override o WHERE o.suite = %s AND o.package = b.package)"""
+ % (suite_id, suite_id));
+ print q
+ q = projectB.query("""
+SELECT DISTINCT s.source FROM source s, src_associations sa
+ WHERE s.id = sa.source AND sa.suite = %s AND NOT EXISTS
+ (SELECT * FROM override o WHERE o.suite = %s and o.package = s.source)"""
+ % (suite_id, suite_id));
+ print q
################################################################################
def main ():
- global Cnf, projectB;
+ global Cnf, projectB, db_files, waste, excluded;
apt_pkg.init();
Cnf = apt_pkg.newConfiguration();
apt_pkg.ReadConfigFileISC(Cnf,utils.which_conf_file());
- Arguments = [('d',"debug","Claire::Options::Debug", "IntVal"),
- ('h',"help","Claire::Options::Help"),
- ('v',"version","Claire::Options::Version")];
+ Arguments = [('d',"debug","Tea::Options::Debug", "IntVal"),
+ ('h',"help","Tea::Options::Help"),
+ ('v',"version","Tea::Options::Version")];
apt_pkg.ParseCommandLine(Cnf,Arguments,sys.argv);
-
projectB = pg.connect('projectb', 'localhost');
-
db_access.init(Cnf, projectB);
- q = projectB.query("SELECT l.path, f.filename FROM files f, location l WHERE f.location = l.id")
- ql = q.getresult();
-
- for i in ql:
- filename = i[0] + i[1];
- if os.access(filename, os.R_OK) == 0:
- print filename
+ check_override();
+ #check_dscs();
+ #check_files();
#######################################################################################