How to debug a Linq Lambda Expression?

55,343

Solution 1

You can't debug a Lambda expression if you're using a Linq to Entities provider.

But you can take a look at what SQL it translate into. Also if you are willing to suffer a performance hit - you could load it all into Linq to obejcts - and do a Step by step

Solution 2

Make sure you read the official MSDN doc on this matter:

Debugging LINQ

and please vote for this suggestion on Visual Studio's User Voice page:

Debug Lambda expressions

Allon Guralnek comments on March 18, 2014 12:37 PM about a way of setting a breakpoint with the keyboard only:

@Anonymous: You can do this today by setting a breakpoint inside the lambda, thereby enabling you to inspect each value that comes in and out of the lambda. As far as I know, you can't set a breakpoint inside a lambda using the mouse, you must use the keyboard. Put the cursor inside the lambda body (e.g. on the first token, or anything after the => and the whitespace that follows) then press F9 (or whatever keyboard shortcut you use to place a breakpoint). Only the inside of the lambda statement will turn red, and the debugger will break there for each item the lambda is evaluated against (so for an array of 100 items, using .Where() will cause the breakpoint to hit 100 times).

Here's it in action in my current Visual Studio 2013:

enter image description here

As you can see it works pretty well and allows us to see the value of a given property being tested. This is for sure an awesome tool/life saver! :)

Solution 3

You can add breakpoints on any of your own code.

So put the cursor at 'x.e', and press F9.

Solution 4

For any future readers, this has now been included in Visual Studio. Starting from Visual Studio 2015 Preview, you can now debug lambda expression during debugging. All debug windows including Watch, QuickWatch and Immediate support lambda expression evaluation. You can read more about this here.

Solution 5

No there is no way to see values of x nor e variables because linq to orm is not executed it is translated/interpreted to generate an sql query.

Share:
55,343
GibboK
Author by

GibboK

A professional and enthusiastic Senior Front End Developer. Listed as top 2 users by reputation in Czech Republic on Stack Overflow. Latest open source projects Animatelo - Porting to JavaScript Web Animations API of Animate.css (430+ stars on GitHub) Industrial UI - Simple, modular UI Components for Shop Floor Applications Frontend Boilerplate - An opinionated boilerplate which helps you build fast, robust, and adaptable single-page application in React Keyframes Tool - Command line tool which convert CSS Animations to JavaScript objects gibbok.coding📧gmail.com

Updated on January 26, 2020

Comments

  • GibboK
    GibboK over 4 years

    I am using Entity Framework and Linq to Entitites.

    I would like to know if there is any way in Visual Studio 2012 to debug this code, step by step. At the moment when placing a break point, the cursor goes over it but does not step inside.

    I am more interested to see the value of x.e... not the sql generated for example.

    Notes: I'm fine with using other tools or Visual Studio plugins.

              IEnumerable<EventPushNotification> eventToPushCollage = eventsForEvaluation
                        .GroupJoin(eventCustomRepository.FindAllPushedEvents(),
                            e => e.Id,
                            p => p.PushedEventId,
                            (e, p) => new { e, p })
                         .Where(x => x.e.DateTimeStart > currentDateTime &&
                            currentDateTime >= x.e.DateTimeStart.AddMinutes(defaultReminders) &&     //  Data from default reminder for collage event in web.config  
                            x.p.Count() == 0)                                           // Check if the Event has not being already pushed
                         .Select(y => new EventPushNotification
                         {
                             Id = y.e.Id,
                             EventTitle = y.e.EventTitle,
                             DateTimeStart = y.e.DateTimeStart,
                             DateTimeEnd = y.e.DateTimeEnd,
                             Location = y.e.Location,
                             Description = y.e.Description,
                             DeviceToken = y.e.DeviceToken
                         });