views:

94

answers:

5

The following issue is becoming increasing common:

  • There are several developers working on a project which includes new files (usually images)
  • Everyone says that everything is checked in and we freeze development. Unbeknownst to us, there are images which were not checked in. The user doesn't notice the missing files because they're new, not check-outs, so svn looks fine
  • The code is compiled and deployed (sorry, no QA team)
  • The next day the client tells us about the missing images
  • The CTO reads us the riot act

Note: The image paths are both in code and in databases so it's not easy to get a full list of all used images.

My hope is to write a small C# program for everyone to run before deployment. I want to find out which files in the project directory (or one of it's subdir.s, recursively) have not been added to subversion. Ideally, I'd also like to exclude items which were actively added to the ignore list.

We're using TortoiseSVN with Windows host and clients.

How can I programmatically discover non-added files?

The closest thing I've been able to find so far is this saying to use svn status | grep -e ^? but this looks like a Unix command.

A: 
svn status | grep -e ^?

It's unix command, but I'm pretty sure, than if you execute commit from Tortoise, you are able to see new files with question mark, that are files which are not under svn control

Ency
searching for files with question mark in Tortoise isn't a programmatic solution to the problem.
Sander Rijken
I just wanted to show, there could be problem on a different place...
Ency
+3  A: 

You could use SharpSvn for this, and write something like:

SvnClient client = GetClient();

client.Status(workingCopyPath, (o, e) =>
{
    if(e.LocalContentStatus == SvnStatus.NotVersioned)
    {
        Console.WriteLine("Not versioned: " + e.FullPath);
    }
});

Edit: this will also respect your ignore file and svn:ignore properties.

Sander Rijken
@Sander Rijken: Thanks for the tip. This library looks it could be exactly what I need. Because of its terrible lack of documentation or examples I can't figure out how to use it but I'll keep playing around with it.
Dinah
+1  A: 

You could install the CollabNet Subversion Command-Line Client, then run its svn command as a subprocess, pipe its input into your program, and search for lines that have ? as their first character (indicating unknown / not checked into Subversion and not ignored). You can use CollabNet's command-line client along with TortoiseSVN.

That's the same thing that svn status | grep -e ^? does, but it doesn't depend on Unix tools.

Alternatively, you could just install Cygwin and have the full range of Unix tools at your disposal.

Josh Kelley
+6  A: 

The code is compiled and deployed (sorry, no QA team)

Isn't this the real problem here? If you're shipping untested code to a client, then of course the first person to discover any problems will be the client. Perhaps (in addition to fixing this particular problem) what you need to do is add at least some basic automated (or manual) functionality testing into your build process, sometime between when the code is compiled and when it is handed over to the client.

Jeremy Friesner
I certainly can't argue with you here but my power in this matter is extremely limited.
Dinah
+1  A: 

This question is tagged as tortoisesvn so I assume your team is using TortoiseSVN as a client. As @Joe Enos suggested, TortoiseSVN displays the unversioned files that do not match the entries in svn:ignore. I wonder if adding another tool may help since the team should already be checking for unversioned files with TortoiseSVN.

Otherwise, a C# program seems like overkill for finding unversioned files in an SVN working directory. As @Josh Kelley suggested, you can just use a command-line SVN client (CollabNet or Slik SVN, for example) and grep.

You can also use the findstr command available in the Windows command line:

svn status | findstr "^?"
Jaime Soto