I got totally confused about making these changes.
Lets say that we have a table in the database, lets call it Customers.
We get the data from the table by using the entity framework, like that:
List<Customers> customers = context.Customers.ToList(); 
We also have a BindingSource and we use the List<Customers as a data source:
bindingSource1.DataSource = customers;
And in the end, we assign the binding source as a data source of the DataGridView:
dataGridView1.DataSource = bindingSource1;
Now lets say that we want to add a new customer. What is the proper way to perform add/change on the data? Should we add/update the List<Customers> and in the end just save the context?
Also in the same time, what is the proper way to cancel the changes? Assuming that we use some of the suggestions mentioned here: How to Refresh DbContext and here: https://code.msdn.microsoft.com/How-to-undo-the-changes-in-00aed3c4
When the changes in the context are cancelled(all modified, deleted and added entries are cancelled), how do we update the DataGridView or the BindingSource?
I think I am missing a piece of the puzzle.
 
                        
I've come to the solution and it is to use a two-way data binding. That way all sides will get notified when we add, edit or delete records from the grid. Microsoft have a tutorial here LINK but there are also other ways.