20

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.

Dinah
  • 52,922
  • 30
  • 133
  • 149
  • 4
    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 Oct 13 '10 at 19:02
  • 5
    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ć Oct 13 '10 at 19:04
  • 5
    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 Dec 20 '12 at 05:01
  • @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 UI – Shirish Herwade Jan 19 '16 at 05:54
  • @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 Jan 19 '16 at 15:12

6 Answers6

16
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
  • 633
  • 5
  • 16
11

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 "^?"
Community
  • 1
  • 1
Jaime Soto
  • 3,168
  • 1
  • 21
  • 19
  • The findstr trick is excellent! Thanks to you I now have a batch file that can tell me every file that has been added or deleted between certain revisions. `svn diff -r REVNO:HEAD --summarize | findstr "^A" > AddedFiles.txt` `svn diff -r REVNO:HEAD --summarize | findstr "^D" > DeletedFiles.txt` Just change REVNO and HEAD to whatever range you like. Thanks to this page too: http://muffinresearch.co.uk/archives/2008/09/15/svn-tip-get-list-of-files-changed-between-revisions/ – Danny Parker Jul 04 '12 at 11:20
  • I ran this command nothing shows up svn status | findstr "^?" – HaBo Apr 06 '16 at 11:07
7

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
  • 70,199
  • 15
  • 131
  • 234
  • 1
    I certainly can't argue with you here but my power in this matter is extremely limited. – Dinah Oct 13 '10 at 19:07
  • 1
    Your developers are suffering when they don't have tests. Tests give you freedom from fear of touching things. – doug65536 Dec 20 '12 at 05:05
6

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
  • 21,376
  • 3
  • 61
  • 85
  • 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 Oct 13 '10 at 19:30
2

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

Shirish Herwade
  • 11,461
  • 20
  • 72
  • 111
1

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
  • 56,064
  • 19
  • 146
  • 246