Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8738093
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 13, 20262026-06-13T10:40:16+00:00 2026-06-13T10:40:16+00:00

Here is my class: public class AuditInfo { public String ActionDescription { get; set;

  • 0

Here is my class:

public class AuditInfo
{
    public String ActionDescription { get; set; }
    public String ActionWho { get; set; }
    public BasicProjectProfile Project { get; set; }


    public AuditInfo ()
    { }

    public void SaveInfo ()
    {
        using (CIHEntities _dbContext = new CIHEntities())
        {
            AuditInfoEntity aie = new AuditInfoEntity();
            aie.ActionDescription = this.ActionDescription;
            aie.ActionWhen = DateTime.Now;
            if (this.ActionWho != null)
            {
                aie.ActionWho = this.ActionWho;
            }
            else
            {
                aie.ActionWho = "Not Specified";
            }
            aie.ProjectAssoc = _dbContext.ProjectEntity
                .Where(r => r.Id == this.Project.Id)
                .First();
            _dbContext.SaveChanges();
        }
    }
}

CIHEntities is a Entity Framework Database.

I would like to unit test the SaveInfo method but it shouldn’t actually save to the Database. How Can this be done?

Thanks

Eric

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-13T10:40:17+00:00Added an answer on June 13, 2026 at 10:40 am

    use the Repository pattern and move the responsibility for saving the enity to the Repository:

    public class AuditInfo
    {
        public String ActionDescription { get; set; }
        public String ActionWho { get; set; }
        public BasicProjectProfile Project { get; set; }
    }
    

    write an interface for your repository:

    public interface IRepository
    {
        void Save();
    }
    

    then your implemention:

    public RealRepository : IRepository
    {
        public void SaveInfo ()
        {
            using (CIHEntities _dbContext = new CIHEntities())
            {
                AuditInfoEntity aie = new AuditInfoEntity();
                aie.ActionDescription = this.ActionDescription;
                aie.ActionWhen = DateTime.Now;
                if (this.ActionWho != null)
                {
                    aie.ActionWho = this.ActionWho;
                }
                else
                {
                    aie.ActionWho = "Not Specified";
                }
                aie.ProjectAssoc = _dbContext.ProjectEntity
                    .Where(r => r.Id == this.Project.Id)
                    .First();
                _dbContext.SaveChanges();
            }
        }
    }
    

    then make your client code that takes a repository as a parameter will be something like this

    public class MyClient{
    
        IRepository _repository;
    
        public MyClient(){
            _repository = new RealRepository();
        }
    
        public MyClient(IRepository repository)
        {
            _repository = repository;
        }
    
        public void Main(){
             AuditInfo entity = new AuditInfo();
             //do whatever you want
             _repository.Save();
        }
    }
    

    Your real application can use the default constructor which will use the RealRepository while you unit tests can can pass a Fake Repository implementation that doesn’t talk to the database (or even better use a Mocking framework like Moq).

    This is the basic concept, you can improve it to have a Generic Repository, use UoW pattern … You can read more about it in this msdn article: Testability and EF

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Here's my model: public class StockRequestModel { public int StockID { get; set; }
Here is the class: functions.php class buildPage { public function Set($var,$val){ $this->set->$var = $val;
Here is the code: class Time { public static void printTime (int hour, int
Here is my class: public class Command { [XmlArray(IsNullable = true)] public List<Parameter> To
I have a few classes as shown here public class TrueFalseQuestion implements Question{ static{
here is a class code : > [DataObjectAttribute] public class > Report { public
Hello everyone here is my DAO class : public class UsersDAO extends HibernateDaoSupport {
For the sake of argument, here's a simple person class public class Person :
Here is my model: public class RestoreRequestModel : IDataErrorInfo { //true seems Value contains
Here's the code: class qual { public static int fibonacci(int n) { if (n

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.