19
votes

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.

6
Not an answer, but when I commit via Tortoise, I always have the "Show unversioned files" box checked. This shows every file in the directory that hasn't been added yet, and reminds me to check them in. Stuff that you want to ignore (.suo, .user, ReSharper files, etc.) can be ignored one time, and it will prevent this from uglying up the diff data, leaving only true non-checked-in files.Joe Enos
It sounds like a people problem to me. "Everyone says that everything is checked in" is not enough, next person to break the build should pay 10$ (piggy bank for the team). Creating a tool to check if another tool is used correctly sounds very wrong.Nikola Smiljanić
No matter how hard we try, we are going to break the build at least sometimes. (Trying so hard that we NEVER break it is a waste of time). This is good question because in my experience, the #1 checkin mistake is missing new files.doug65536
@JoeEnos in our case, '"Show unversioned files" box checked' never showed new files that are not added. We used 'TortoiseSVN 1.8.0, Build 24401 - 64 Bit , 2013/06/17 18:15:59 Subversion 1.8.0, -release on windows7' with UIShirish Herwade
@ShirishHerwade It's been awhile since I've used SVN, but I wouldn't expect that behavior to have changed. My best guess would be those missing files are already in your ignore list.Joe Enos

6 Answers

15
votes
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

11
votes

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 "^?"
7
votes

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.

6
votes

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.

1
votes

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.

1
votes

Also you can change one settings which will show folders having new added files as modified.

Settings->Icon Overlays->Show overlay for unversioned item

Right-click in folder, then navigate TortoiseSVN - Settings. Click on 'Icon Overlays'. On right-side check - 'Unversioned files mark parent folder as modified'

This works on windows7, not tried with other OS