Question

Business entity with INotifyPropertyChanged implemented is causing WCF Test Client to throw "Object reference not set to an instance of an Object" exception

Asked by: nhhgict

I am trying to create a WCF service to manage a specific business entity ie. Add, Update, Delete.

I am using the test client to test the service and all is well until I implement the INotifyPropertyChanged interface on the business entity and fire a property changed notification on one of the properties.

I receive an "Object reference not set to an instance of an Object" exception in the test client at this point.

Is the test client capable of dealing with entities that implement INotifyPropertyChanged or should I not attempt to use the test client in this situation?

[DataContract]
    public class DisplayDiscipline :BOBase
    {
        private Discipline _theDiscipline;
        
        private BusinessObjectField<Guid> _id;
 
 
        public DisplayDiscipline()
        {           
            _id = new BusinessObjectField<Guid>(Guid.NewGuid());
             _theDiscipline = new Discipline();
        }
 
        
        [DataMember]
        public Guid Id
        {
            get { return _id.Value; }
            set { _id = new BusinessObjectField<Guid>(value); }
        }        
 
        public void SetDiscipline(Discipline newDiscipline)
        {
            _theDiscipline = newDiscipline;
        }
 
        public Discipline GetDiscipline()
        {
            return _theDiscipline;
        }
 
 
 
        [DataMember]
        public string Description
        {
            get { return _theDiscipline.Description; }
            set 
            { 
                _theDiscipline.Description = value;
                FirePropertyChanged("Description");
            }
        }
 
 
        [DataMember]
        public Boolean OnFramework
        {
            get { return _theDiscipline.OnFramework; }
            set
            {
                _theDiscipline.OnFramework = value;
                FirePropertyChanged("OnFramework");
            }
        }
 
        [DataMember]
        public Boolean Deleted
        {
            get { return _theDiscipline.Deleted; }
            set
            {
                _theDiscipline.Deleted = value;
                FirePropertyChanged("Deleted");
            }
        }
 
        public override void Delete()
        {
            _theDiscipline.Delete();
            base.Delete();
        }
    }
----------------------------------
 
//Method in the service library
//created to test adding a business entity to a list
  public void AddDiscipline(DisplayDiscipline discipline)
        {
            List<DisplayDiscipline> list = new List<DisplayDiscipline>();
 
            list.Add(discipline);
        }

                                  
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:
31:
32:
33:
34:
35:
36:
37:
38:
39:
40:
41:
42:
43:
44:
45:
46:
47:
48:
49:
50:
51:
52:
53:
54:
55:
56:
57:
58:
59:
60:
61:
62:
63:
64:
65:
66:
67:
68:
69:
70:
71:
72:
73:
74:
75:
76:
77:
78:
79:
80:
81:
82:
83:
84:

Select allOpen in new window

This Question has been solved and asker verified All Experts Exchange premium technology solutions are available to subscription members.

Subscribe now for full access to Experts Exchange and get

Instant Access to this Solution

  • Plus...
  • 30 Day FREE access, no risk, no obligation
  • Collaborate with the world's top tech experts
  • Unlimited access to our exclusive solution database
  • Never be left without tech help again

Subscribe Now

Asked On
2009-08-12 at 07:44:23ID24646638
Topics

Web Services and WCF

,

Web Services

,

WebApplications

Participating Experts
1
Points
0
Comments
7

Trusted by hundreds of thousands everyday for fast, accurate and reliable tech support.

  • "The time we save is the biggest benefit of Experts Exchange to Warner Bros. What could take multiple guys 2 hours or more each to find is accessed in around 15 minutes on Experts Exchange." Mike Kapnisakis, Warner Bros.
  • "Our team likes having a resource that is more secure than just using Google and most experts using this service really know their stuff. It's nice to look here first versus using Google." Dayna Sellner, Lockheed Martin
  • "Anytime that I've been stumped with a problem, 9 out of 10 times Experts Exchange has either the accepted solution or an open discussion of the potential solution to the problem." Kenny Red, eBay Inc.

See what Experts Exchange can do for you.

Got a question?

We've got the answer.

Experts Exchange has been collecting answers to technology questions since 1996…3 million and counting! If you have a question, chances are we already have your answer.

Screenshot of Experts Exchange Knowledgebase

Need individual assistance?

Our experts are ready to help.

If you can't find the exact answer you're looking for, ask our exclusive community of 50,000 experts. You’ll get a personalized answer from a trusted professional.

Screenshot of Experts Exchange Knowledgebase

Want to learn from the best?

Read articles from industry experts.

Thousands of free tech tips, tricks, how-to’s and tutorials are available in our peer reviewed articles section. See for yourself how smart our experts are, no login required.

Screenshot of an Article

Working on a long term project?

Store your work and research.

Save solutions to your questions, answers you’ve discovered through searching plus helpful articles in your personal knowledgebase for easy future access.

Screenshot of Experts Exchange Knowledgebase

Access the answers to your technology questions today.

Subscribe Now

30-day free trial. Register in 60 seconds.

What Makes Experts Exchange Unique?

Members of the expert community talk about why the experience at Experts Exchange is different than what you will find anywhere else.

Trusted by the world's most respected brands.

image of each brand's logo

Faithfully serving IT professionals since 1996.

Experts Exchange Logo

Try it out and discover for yourself.

Subscribe Now

30-day free trial. Register in 60 seconds.

Related Solutions

  1. entity bean
    do someone know the mechanism of how container can relate the table's row to the entity bean? Do we need to configure the container to tell it which variable in the entity going to match which field in the table? What is the setEntityContext method for?
  2. entity bean ...
    Hi Experts, I created an entity bean from a MS Access database using Blazix12. I got three java(tm) files and a script. However, I couldn't compile any of them. So .... why is that ? Am I supposed to compile a bean ? the following are the java files .... please help ! T...

Free Tech Articles

  1. WARNING: 5 Reasons why you should NEVER fix a computer for free.
    It is in our nature to love the puzzle. We are obsessed. The lot of us. We love puzzles. We love the challenge. We thrive on finding the answer. We hate disarray. It bothers us deep in our soul. W...
  2. SCCM OSD Basic troubleshooting
    SCCM 2007 OSD is a fantastic way to deploy operating systems, however, like most things SCCM issues can sometimes be difficult to resolve due to the sheer volume of logs to sift through and the dispe...
  3. Migrate Small Business Server 2003 to Exchange 2010 and Windows 2008 R2
    This guide is intended to provide step by step instructions on how to migrate from Small Business Server 2003 to Windows 2008 R2 with Exchange 2010. For this migration to work you will need the fo...
  4. Create a Win7 Gadget
    This article shows you how to create a simple "Gadget" -- a sort of mini-application supported by Windows 7 and Vista. Gadgets can be dropped anywhere on the desktop to provide instant information, ...
  5. Outlook continually prompting for username and password
    There have been a lot of questions recently regarding Outlook prompting for a username and password whilst using Exchange 2007. There are a few reasons why this would happen and I will try to cover t...
  6. Backup Exchange 2010 Information Store using Windows Backup
    There seems to be quite a lot of confusion around the ability to backup Exchange 2010 using the built in Windows Backup feature. This stems from the omission of this feature prior to Exchange 2007 s...

Cloud Class Webinars

  1. Avoiding Bugs in Microsoft Access
    Alison Balter takes and in-depth look at avoiding bugs in Access. In this webinar you will learn about using the immediate window to debug your applications, invoking the debugger, using breakpoints to troubleshoot, stepping through code, setting the next statement to execute, ...
  2. Top 10 Best New Features in Visio 2010
    Scott Helmers gives live demonstrations of the top 10 new features in Visio 2010. This webinar will teach you how to create compelling diagrams by adding shapes to the page with a single click, linking the shapes in a diagram to data in Excel (or SQL Server, or SharePoint), ...
  3. IT Consultant Business Secrets Revealed
    Michael Munger, Experts Exchange tech pro and IT consultant, pulls back the curtain on his very successful businesses and answers question on every IT consultant and business owner should know about. He shares secrets on what he did to solve the 5 most common problems in IT, ...
  4. Disaster Recovery and Business Continuity
    Quest CTO, Mike Billon, gives an overview of the steps involved in building a dunamic disaster recovery plan. Through case studies and an examination of software/hardware tooles for monitoring and testing, you'll gain a better understandin of where you are, where you want ...
  5. Organize Your Visio Diagrams with Containers and Lists
    Scott Helmers uses cross functional flowcharts, wireframe diagrams, data graphic legends and seating charts to teach you: how to ustilize all three new structured diagram components in Visio 2010, the best practices for organizeing shapes in previous version of Visio, how to organize ...
  6. How to Us Objects, Properties, Events and Methods in Microsoft Access
    Alison Dalter gives an in-depbth look at objects, properties, events and methods in Microsoft Access. In this webinar you will learn about using the object browser, referring to objects, working with properties and methods, working with object variables, understanding the ...

Join the Community

Give a Little. Get a Lot.

Join the community of experts here and help other tech pros by answering question in your area of expertise. You can earn FREE access to all Experts Exchange's premium features and resources.

Join the Community

Answers

 

by: ToddBeaulieuPosted on 2009-08-12 at 08:30:09ID: 25079727

I suspect your problem is a plain old oversight in object creation. Can you post the definition of "FirePropertyChanged"?

 

by: nhhgictPosted on 2009-08-13 at 00:52:41ID: 25086104

Thanks Todd, here is the code in the base class BOBase.
 [DataContract]
    public class BOBase : INotifyPropertyChanged
    {
        private List<string> _changedFields = new List<string>();

        [DataMember]
        public List<string> ChangedFields
        {
            get { return _changedFields; }
        }

        #region INotifyPropertyChanged Members

        public event PropertyChangedEventHandler PropertyChanged;

        #endregion

       
        public enum BusinessObjectSource
        {
            AddedNotInDb = 0,
            FromDb = 1,
        }
       
        public enum BusinessObjectStatus
        {
            Deleted = 0,
            Modified = 1,
            Unchanged = 2
        }
        BusinessObjectStatus _objectStatus;
        BusinessObjectSource _objectSource;

        public BOBase()
        {
            _objectSource = BusinessObjectSource.AddedNotInDb;
            _objectStatus = BusinessObjectStatus.Unchanged;
        }

        [DataMember]
        public bool IsNew
        {
            get { return _objectSource == BusinessObjectSource.AddedNotInDb; }
            set { _objectSource = BusinessObjectSource.AddedNotInDb; }
        }
        [DataMember]
        public bool IsPhantom
        {
            get
            {
                return _objectSource == BusinessObjectSource.AddedNotInDb &&
                       _objectStatus == BusinessObjectStatus.Deleted;
            }
            set { }
        }

       
        [DataMember]
        public bool IsModified
        {
            get
            {
                return
              _objectSource == BusinessObjectSource.FromDb &&
              _objectStatus == BusinessObjectStatus.Modified;
            }
            set{}
        }
        [DataMember]
        public bool IsDeleted
        {
            get
            {
                return
              _objectSource == BusinessObjectSource.FromDb &&
              _objectStatus == BusinessObjectStatus.Deleted;
            }
            set{}
        }
        [DataMember]
        public bool IsUnchanged
        {
            get
            {
                return
              _objectSource == BusinessObjectSource.FromDb &&
              _objectStatus == BusinessObjectStatus.Unchanged;
            }
            set{}
        }

     
        public virtual void Delete()
        {
            _objectStatus = BusinessObjectStatus.Deleted;
        }

        protected void SetNewPropertyValue<T>(string name, BusinessObjectField<T> theField, T newValue)
        {        
            if (!theField.Value.Equals(newValue))
            {
                theField.Value = newValue;
                FirePropertyChanged(name);                
                _changedFields.Add(name);
            }
        }

        protected void FirePropertyChanged(string p)
        {
            _objectStatus = BusinessObjectStatus.Modified;

            if (PropertyChanged != null)
                PropertyChanged(this, new PropertyChangedEventArgs(p));

        }
       

        /// <summary>
        /// Call AcceptChange on all fields that support an AcceptChange method
        /// </summary>
        public virtual void AcceptChanges()
        {
            Type t = GetType();
            System.Reflection.FieldInfo[] fields = t.GetFields(System.Reflection.BindingFlags.Instance
                        | System.Reflection.BindingFlags.Public
                        | System.Reflection.BindingFlags.NonPublic
                        );

            foreach (System.Reflection.FieldInfo field in fields)
            {
                // Get object reference for the field.  Then we can call the property
                IBOField fieldValue = field.GetValue(this) as IBOField;
                if (fieldValue != null)
                    fieldValue.AcceptChange();
            }

            _objectSource = BusinessObjectSource.FromDb;
            _objectStatus = BusinessObjectStatus.Unchanged;

            _changedFields.Clear();
        }


     
    }

 

by: nhhgictPosted on 2009-08-13 at 01:16:10ID: 25086211

It appears to be failing on the following line of the class DisplayDiscipline.

 _theDiscipline.Deleted = value;

which is in the setter of the property Deleted....

       
       [DataMember]
        public Boolean Deleted
        {
            get { return _theDiscipline.Deleted; }
            set
            {
                _theDiscipline.Deleted = value;
                FirePropertyChanged("Deleted");
            }
        }


I have instantiated _theDiscipline in the constructor so it should not be null at this point.

public DisplayDiscipline()
        {          
            _id = new BusinessObjectField<Guid>(Guid.NewGuid());
             _theDiscipline = new Discipline();
        }


I think the FirePropertyChanged method has nothing to do with the problem, sorry for the misdirection.

Is there something I am missing in terms of where I should be instantiating the object _theDiscipline?

 

by: ToddBeaulieuPosted on 2009-08-13 at 06:08:34ID: 25087741

So DisplayDiscipline has a Discipline instance in it. And it's created in DisplayDiscipline's constructor. Then, later on, from DisplayDiscipline, it tries to set the Deleted property. Is this right? Looks reasonable enough.

Is the Deleted property doing anything that could cause this? Is it anything but a simple property setter?
You can always throw an Assert in, just above "_theDiscipline.Deleted = value;" to test _theDiscipline for null.

Without error handling, it's quite easy to assume that the failing line is causing the error, and miss the fact that it's actually failing several levels down into that call. You need to really be careful when evaluating the call stack.

Finally, rather than going through the underlying variables for properties, I generally like to go through ther accessors so that I can debug problems like this. So, let's say you have the line "_theDiscipline = new Discipline();", yet somehow later on that variable is null. How do you know if it's being set elsewhere? You don't, unless everything goes through "This.Discipline = new Discipline();". Now you can instrument that setter and breakpoint or log all sets to see if you're forgetting about something else that's messing with the value after your constructor's initialized it.

 

by: nhhgictPosted on 2009-08-13 at 07:37:54ID: 25088741

Yes The setter tries to set the Discipline.Deleted property to the value of the setting property.

ie. _theDiscipline.Deleted = value;

I like your suggestion about using the accessors instead of using the underlying fields to change the value of a property, I will give it a try, at least I will be more sure of the source of any errors.

I think the issue may be arising from the fact that WCF will not run any constructor or method code when it serialises out to the client.

I have tried adding an OnDeserialised method to the DisplayDiscipline class which instantiates the Discipline class in the same way that the constructor would have, but still no luck.

I am now wondering whether the WCF Test Client is the right tool to test the operation of my service i nthese circumstances.

What I will do now is creating my own proxy in a class library project that calls the service directly and see if this works.

Do you have any other suggestions?



 

by: ToddBeaulieuPosted on 2009-08-13 at 07:44:02ID: 25088837

I think you are on the right path.

http://mehranikoo.net/CS/archive/2007/11/09/DataContractConstructorsInWCF.aspx

Here's a small excerpt:

>>Something that you need to be aware of is that the parameter-less constructor for the data contract is only called when the object is instantiated by your code. So for example, when you call a WCF service and the service returns a data contract, WCF runtime on the client side does not call the parameter-less constructor, which makes sense as the returned message includes all the state you need and there is no point in running the constructor. If you need to perform an operation when the message is received by the client, you can use OnDeserializingAttribute or OnDeserializedAttribute defined in System.Runtime.Serialization namespace.

 

by: nhhgictPosted on 2009-08-17 at 02:46:35ID: 25112718

It appears in my case that the error is caused by the contructor code not being deserialised on the client side.

I added an [OnDeserisalized] method which handles the instantiation of the fields which I use in the properties of my business entity.

  [OnDeserialized]
        private void OnDeserialised(StreamingContext context)
        {
            _id = new BusinessObjectField<Guid>(Guid.NewGuid());
            _description = new BusinessObjectField<string>(string.Empty);
            _onFramework = new BusinessObjectField<bool>();
            _deleted = new BusinessObjectField<bool>();
        }

I have also decided to keep my model simple and do not use DisplayDiscipline to present Discipline. I use now Discipline as my data contract instead.

20120131-EE-VQP-002

3 Ways to Join

30-Day Free Trial

The Experts

98% positive feedback on 31,087 answers since March 2000. angeliii is a Microsoft Most Valuable Professional for his work with MS SQL Server & Develoment.

He has also proven his knowledge of Visual Basic Programming, PHP Scripting and Oracle Databases.

The Experts

97% positive feedback on 10,752 answers since July 2000. lrmoore has more than 18 years experience in the networking industry.

The six-time Mircosoft MVPs specialties include firewalls, virtual private networking, and network management.

Testimonials

"...and excellent source for support... Kind of like having your very own IT dept." Electriciansnet

Testimonials

"I was apprehensive at signing up at first. However... it has already made my life as an IT administrator much easier." JaCrews

Testimonials

"WOW! You guys have great, active, and knowledgeable people on here." moore50

Business Clients

Business Clients

In the Press

"If you’ve got a question... Experts Exchange can supply an answer.”

In the Press

"...an invaluable aid for both IT professionals and those who require tech support."

In the Press

"where IT professionals provide quick answers on just about any topic"

Business Account Plans

Loading Advertisement...