Search This Blog
Thursday, October 29, 2009
SCM(Software Configuration Management)
http://www.rspa.com/spi/SCM.html
In software engineering, software configuration management (SCM) is the task of tracking and controlling changes in the software. Configuration management practices include revision control and the establishment of baselines.
SCM concerns itself with answering the question "Somebody did something, how can one reproduce it?" Often the problem involves not reproducing "it" identically, but with controlled, incremental changes. Answering the question thus becomes a matter of comparing different results and of analysing their differences. Traditional configuration management typically focused on controlled creation of relatively simple products. Now, implementers of SCM face the challenge of dealing with relatively minor increments under their own control, in the context of the complex system being developed.
Friday, October 23, 2009
ASP.NET Interview Questions
http://asp-interviewquestions.blogspot.com/2009/05/written-test-or-practical-aspnet.html
Wednesday, October 21, 2009
Thursday, October 15, 2009
Multi-Threading in .NET
http://www.freevbcode.com/ShowCode.Asp?ID=1287
http://msdn.microsoft.com/en-us/library/system.threading.aspx
Wednesday, October 14, 2009
CodeDom in .NET
http://www.codeproject.com/KB/dotnet/CompilingWithCodeDom.aspx
http://msdn.microsoft.com/en-us/library/f1dfsbhc%28VS.80%29.aspx
http://msdn.microsoft.com/en-us/library/y2k85ax6%28VS.71%29.aspx
Native Image Generator (Ngen.exe)
> http://www.codeproject.com/KB/aspnet/Ngen.aspx
Microsoft .NET Code Access Security(CAS)
> http://www.15seconds.com/Issue/040121.htm
Wednesday, October 7, 2009
Tuesday, October 6, 2009
Descriptive Programming in QTP
Make a FREE Website Fast and Easy No hidden fees. No technical skills needed.
Friday, October 2, 2009
Journey to SQL Authority with Pinal Dave
Friday, September 18, 2009
Tuesday, September 15, 2009
Tuesday, September 8, 2009
QTP Version Difference
Object Repoistory Manager
Each object repository contains the information that enables QuickTest to identify the objects in your application. QuickTest enables you to maintain the reusability of your tests by storing all the information regarding your test objects in a shared object repository. When objects in your application change, the Object Repository Manager provides a single, central location in which you can update test object information for multiple tests.
If an object with the same name and description is located in both the local object repository and in a shared object repository that is associated with the same action, the action uses the local object definition. If an object with the same name and description is located in more than one shared object repository, and these shared object repositories are all associated with the same action, QuickTest uses the object definition from the first occurrence of the object, according to the order in which the shared object repositories are associated with the action.
You can use the same shared object repository with multiple actions. You can also use multiple object repositories with each action. Therefore, when the property values of objects in your application change, you should modify the corresponding test object property values in the corresponding object repository so that you can continue to use your existing tests. You can modify objects in a shared object repository using the Object Repository Manager. You can modify objects stored in a local object repository using the Object Repository window.
qtp: object spy in QTP
Object spy is the very much important tool in qtp. With the use of Object spy we can learn basic structure of test object. The main advantage of object spy is that we can see object structure of specific object in tree view. So that makes test object more understandable and easier.
In addition to this we can view the run-time and test object properties and methods of any object in open application.
Now let’s understand and use object spy practically.
How to use Object spy in qtp?
1. Go to Tools->Object spy.
2. One window named Object Spy will open
3. Then open the application whose object properties or methods you want to see.
4. Then just click on “Pointer image” of object spy window.
5. Click on Object whose object properties or methods you want to see.
Above figure is window of object spy. I have used “object Spy” tool on “google.com” logo “Google’. QTP recognize this logo 'Google' as image. Using Object spy you can view two things one is properties of specific object and second is methods applicable for that object.
Use of Object spy:
- You can view different object properties of selected objects.
- Let’s see some example, you can know file name of image see in fig. �"
Thursday, September 3, 2009
How to remove Spyware
Tuesday, August 25, 2009
Bug Life Cycle & Guidelines
Introduction:
Bug can be defined as the abnormal behavior of the software. No software exists without a bug. The elimination of bugs from the software depends upon the efficiency of testing done on the software. A bug is a specific concern about the quality of the Application under Test (AUT).
Bug Life Cycle:
In software development process, the bug has a life cycle. The bug should go through the life cycle to be closed. A specific life cycle ensures that the process is standardized. The bug attains different states in the life cycle. The life cycle of the bug can be shown diagrammatically as follows:
The different states of a bug can be summarized as follows:
1. New
2. Open
3. Assign
4. Test
5. Verified
6. Deferred
7. Reopened
8. Duplicate
9. Rejected and
10. Closed
Description of Various Stages:
1. New: When the bug is posted for the first time, its state will be “NEW”. This means that the bug is not yet approved.
2. Open: After a tester has posted a bug, the lead of the tester approves that the bug is genuine and he changes the state as “OPEN”.
3. Assign: Once the lead changes the state as “OPEN”, he assigns the bug to corresponding developer or developer team. The state of the bug now is changed to “ASSIGN”.
4. Test: Once the developer fixes the bug, he has to assign the bug to the testing team for next round of testing. Before he releases the software with bug fixed, he changes the state of bug to “TEST”. It specifies that the bug has been fixed and is released to testing team.
5. Deferred: The bug, changed to deferred state means the bug is expected to be fixed in next releases. The reasons for changing the bug to this state have many factors. Some of them are priority of the bug may be low, lack of time for the release or the bug may not have major effect on the software.
6. Rejected: If the developer feels that the bug is not genuine, he rejects the bug. Then the state of the bug is changed to “REJECTED”.
7. Duplicate: If the bug is repeated twice or the two bugs mention the same concept of the bug, then one bug status is changed to “DUPLICATE”.
8. Verified: Once the bug is fixed and the status is changed to “TEST”, the tester tests the bug. If the bug is not present in the software, he approves that the bug is fixed and changes the status to “VERIFIED”.
9. Reopened: If the bug still exists even after the bug is fixed by the developer, the tester changes the status to “REOPENED”. The bug traverses the life cycle once again.
10. Closed: Once the bug is fixed, it is tested by the tester. If the tester feels that the bug no longer exists in the software, he changes the status of the bug to “CLOSED”. This state means that the bug is fixed, tested and approved.
While defect prevention is much more effective and efficient in reducing the number of defects, most organization conducts defect discovery and removal. Discovering and removing defects is an expensive and inefficient process. It is much more efficient for an organization to conduct activities that prevent defects.
Guidelines on deciding the Severity of Bug:
Indicate the impact each defect has on testing efforts or users and administrators of the application under test. This information is used by developers and management as the basis for assigning priority of work on defects.
A sample guideline for assignment of Priority Levels during the product test phase includes:
- Critical / Show Stopper — An item that prevents further testing of the product or function under test can be classified as Critical Bug. No workaround is possible for such bugs. Examples of this include a missing menu option or security permission required to access a function under test.
. - Major / High — A defect that does not function as expected/designed or cause other functionality to fail to meet requirements can be classified as Major Bug. The workaround can be provided for such bugs. Examples of this include inaccurate calculations; the wrong field being updated, etc.
. - Average / Medium — The defects which do not conform to standards and conventions can be classified as Medium Bugs. Easy workarounds exists to achieve functionality objectives. Examples include matching visual and text links which lead to different end points.
. - Minor / Low — Cosmetic defects which does not affect the functionality of the system can be classified as Minor Bugs.
Guidelines on writing Bug Description:
Bug can be expressed as “Result followed by the action”. That means, the unexpected behavior occurring when a particular action takes place can be given as bug description.
- Be specific. State the expected behavior which did not occur - such as after pop-up did not appear and the behavior which occurred instead.
- Use present tense.
- Don’t use unnecessary words.
- Don’t add exclamation points. End sentences with a period.
- DON’T USE ALL CAPS. Format words in upper and lower case (mixed case).
- Mention steps to reproduce the bug compulsorily.
Thursday, August 20, 2009
Wednesday, August 19, 2009
Software testing Video
http://www.youtube.com/watch?v=B_yYAbQVitQ&feature=channel
Tuesday, July 21, 2009
SharePoint Quick Start FAQ Part 2
PreRequisite
Introduction
How can I create my first site in SharePoint?
What is Quick Launch menu?
We have heard that we can customize SharePoint sites how do we do that?
We have heard it has ready made functional modules for collaboration?
How can we enable these reusable components in my site?
How can we display a simple custom page in SharePoint?
The above page does not look like a standard SharePoint page?
Above code is completely inline, how can we implement behind code in SharePoint?
What is the concept of features in SharePoint?
Can you explain the broader steps for deploying / activating a feature?
I want that the feature should be only displayed to admin?
Source code
Pre-requisite
You need to read the previous article to understand the basics First Article of Share Point
Introduction
In the previous session of SharePoint article we had discussed about the basics of SharePoint. In this session we will:-
. create site / site collection
. Understand the ready made functional reusable modules
. Learn how we can display a simple page and later apply master pages of SharePoint.
. Host a Inline code and behind code page in SharePoint
. Understand the concept of features and understand step by step how to enable / disable a feature
. How do display a feature in Admin
For past some days I have been writing and recording videos in design patterns, UML, FPA, Enterprise blocks and lot you can watch the videos at http://www.questpond.com/
You can download my 400 .NET FAQ EBook from http://www.questpond.com/SampleDotNetInterviewQuestionBook.zip
How can I create my first site in SharePoint?
When you want to create any site in SharePoint we need to prepare a site collection and define site inside the site collection. Ok, that's a simple four step procedure and can be easily achieved by using the SharePoint central administration.
Step 1:- Click on start and you should find the SharePoint central administration menu.
Step 2:- Once you click on the central administration menu you need to click on the 'application management' tab and then click 'Create site collection'.
Step 3:- Once you click 'Create site collection' you should see a form which needs all necessary details to create a site. All details are almost self-understandable. We have just stressed on three points one is the site name, the other is a template and the last is the username in which SharePoint will run. All sites in SharePoint need to be inherited from some master they can not stand on their own.
Step 4:- Once you have clicked 'Ok' you can now run the URL with your SharePoint name you should see something as shown below. As we have created from a blank site currently we do not have anything. Below is how a blank site looks like.
What is Quick Launch menu?
Below figure shows what is the quick launch menu. In this question we just wanted to make sure you know the terminology and where it maps to. In the further section we will be using this terminology for the left hand menu shown in the figure below.
We have heard that we can customize SharePoint sites how do we do that?
We will continue with the same example of our blank site which we discussed previously. On the left hand side corner you will see a site actions menu. So click on the site action menu and click on site settings menu link. Once you click on the link you will be popped with different settings by which you can do customization. We will not discuss right now what every setting is, but in the later section we will understand some important settings by which we can achieve customization.
To increase your confidence you can play around with the 'Look and feel' settings. But this will be the landing page when we want to implement customization in SharePoint.
We have heard it has ready made functional modules for collaboration?
Oh, yes you have heard it loud, right and clear. The best part about SharePoint is collaboration. Collaboration has four major entities people, task, data and communication.
So below are some key points of enterprise:-
. We have people in our organizations.
. People are assigned task.
. To complete task we need to exchange data.
. We also need to plan/monitor tasks.
. To communicate data we need a communication channel like email, WIKI etc.
SharePoint has lot of ready made function which can help us to accommodate all the requirements of collaboration. To see those ready made functionalities click on site actions and click on create. You will be popped with a list of reusable functionality page which you can pick up and achieve collaboration.
Now let's map the ready made functionalities with collaboration requirements.
Ready made functionalities in SharePoint | ||
People | Contacts | You can get this section in the communication section of the create page. It creates page which can help us to maintain contact information about people. |
Task | Tasks | You can get this in the tracking section of the create page. It helps us to track task which your team member needs to complete. |
Data | Document library | Its helps to share, edit and version documents. |
Picture Library | Helps to share picture documents | |
Translation management | Helps to create document in multilingual languages. | |
Data connection library | It helps to share files that contain information about external data. | |
Monitoring | Project task | You can get this in the tracking section of the create page. It gives a Gantt chart view of tasks. |
Issue tracking | You can get this reusable functionality in the tracking section of create page. Its helps to manage / assign and prioritize issues from start to finish. | |
Calendar | Helps to create calendar for deadlines and events | |
Communication | WIKI | Helps to create interconnected system like WIKI. |
Announcement | Helps to share news and status through announcements. | |
Discussion board | Helps to create discussion board like the news group. |
How can we enable these reusable components in my site?
Ok, now that we are familiar with the reusable components and how they map to the collaboration requirements. Its time add one reusable functionality in your website. We will add a link inside the documents menu called as 'SharePoint tutorial'. In this section team can upload tutorials for SharePoint in word document format. It's a simple three step process so let's understand the same step by step.
Step 1:- Click on the site actions and click on create link from the menu. You will be displayed reusable functionalities provided by SharePoint. Select 'Document library' from the libraries section.
Step 2 :- Give the link name as 'SharePoint tutorial' and select document types to be unloaded as word format. For this you need to select the document template to be of type 'Microsoft word'.
Step 3:- Bravo! You can now see the SharePoint tutorial link and you can click on upload to push in a word document inside this library collection.
You can see from the figure below how we have uploaded a word document i.e. "SharePoint tutorial". You can right click and experiment with more functionalities like check out , versioning , workflow , send alerts when document is modified etc etc.
Note: - You can try adding other functionalities like WIKI, announcement board, picture library and lot more. So feel free to experiment and see how you can easily leverage the reusable functionalities to meet the collaboration requirements.
How can we display a simple custom page in SharePoint?
Ok first thing there is no concept of simple page in SharePoint. There are two types of pages in SharePoint as we discussed in the previous article one is an Application page and the other is the site page.
Application page is a generic page while site pages are custom to a website. To just cool you off lets display a simple Application page first.
Some points to be noted about Application pages:-
. They are pages which are shared across sites like 'settings.aspx' , which will helps us set generic properties across sites in a site collection.
. The second important part is that we need to save application pages in 'C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\TEMPLATE\LAYOUTS' folder. If you browse to the folder you will find SharePoint's own application pages.
Ok, what we will do is that to build confidence let's make a simple page called as 'SimplePage.aspx'. We are not doing anything great in this we will just write this simple sentence inside the page.
Ohhhh I never Knew SharePoint is so easy |
Once you have saved the page just browse to the IIS application and browse to the _layouts folder as shown in the figure below. If you open the page in browser you should see your display message.
Note: - For the next question you need to understand the concept of master pages. If you have not please read it once. Consistent look and feel is one of the most important factor in enterprise portal and SharePoint achieves the same using Master pages.
The above page does not look like a standard SharePoint page?
In order to get the SharePoint look and feel we need to inherit from a SharePoint master page. As a rule you should always inherit from a SharePoint master page so that your sites have a consistent look and feel. So let's modify our 'SimplePage.aspx'. To get the SharePoint style we need to inherit from the SharePoint master page 'Application.Master'.
We have now tailored the 'simplepage.aspx' source code as shown below. We need to do the following:-
. First refer the assembly using the 'Assembly directive.
. Refer the masterpage files as 'Application.master'.
. Import the sharepoint namespace. If we had used the behind code we would have imported this in the behind code itself.
. There are three placeholder one for title , one for centre area and one for the page title. We need to define the placeholders in the child page.
<%@ Assembly Name="Microsoft.SharePoint,Version=12.0.0.0, Culture=neutral,PublicKeyToken=71e9bce111e9429c" %> <%@ Page Language="C#" MasterPageFile="~/_layouts/application.master" Inherits="Microsoft.SharePoint.WebControls.LayoutsPageBase" %> <%@ Import Namespace="Microsoft.SharePoint" %> Let's learn SharePoint.... Oh its Damn Simple..... SharePoint is Simple..... |
LOL !...Your SharePoint page now looks like a page.
You can get the source of the simple inline ASPX file attached at the end of the article.
Above code is completely inline, how can we implement behind code in SharePoint?
Some couple of points we need to take care regarding implementing behind code in ASP.NET are the following:-
. The first and foremost requirement is that behind code should be registered in to the GAC assembly. In other words we need to code the behind code in a separate assembly / namespace and then compile the same in a DLL. Later we need to register the DLL in GAC.
. Second we need to use the assembly directive to refer the behind code.
Step 1:- So the first step is to make two solution files one is the behind code which goes in separate assembly 'ClassLibrary1' namespace and the other is the ASP.NET web project which has the 'SimplePageCodeBehind.aspx'. We also need to register this DLL in a GAC. So you need to generate a strong name give to the assembly and register the same using the 'GACUTIL' provided by the .NET framework.
Step 2:- The behind code is in a separate assembly as need to register the same in the GAC. We have kept the behind code simple. We have create two label objects and set the value. One of the important points to be noted is that we have referenced the 'System.Web.UI' namespace DLL and 'Microsoft.SharePoint' namespace DLL. The other point to be noted is that the class inherits from 'LayoutsPageBase' class which belongs to 'Microsoft.SharePoint' namespace.
using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; // need to refer the UI objects of ASP.NET using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; // Need to refer the SharePoint DLL using Microsoft.SharePoint; using Microsoft.SharePoint.WebControls; namespace ClassLibrary1 { // Inherit the behind code from 'LayoutsPageBase' class of SharePoint public partial class _Default : LayoutsPageBase { protected Label lblSiteQuestion; protected Label lblSiteAnswer; protected override void OnLoad(EventArgs e) { lblSiteQuestion.Text = " How can we implement behind code in SharePoint ?"; lblSiteAnswer.Text = " We need to register the behind DLL in GAC"; } } } |
We need to also register the above DLL in GAC. So we need to generate a strong name and register the same using GACUTIL.
Step 3:- Now comes the UI part of the ASP.NET i.e. the ASPX page. Below is the code snippet which shows how the ASP.NET UI looks like.
The first thing to note is that behind code is not referred as code behind but is referred using the GAC public token key. In order to refer it using GAC key we need to use the 'Assembly' attribute for the same.
We have also inherited from the master page file i.e. 'Application.Master' so that we have a consistent look and feel.
<%@ Assembly Name="Microsoft.SharePoint,Version=12.0.0.0, Culture=neutral,PublicKeyToken=71e9bce111e9429c" %> <%@ Assembly Name="ClassLibrary1, Version=1.0.0.0, Culture=neutral,PublicKeyToken=af6d081bf267e17e" %> <%@ Page Language="C#" MasterPageFile="~/_layouts/application.master" Inherits="ClassLibrary1._Default" EnableViewState="false" EnableViewStateMac="false" %> |
Once we have referred the Assembly and set the Page attributes. Its time to fill the content in the placeholders defined in the master page 'Application.Master'.
SharePoint Behind code implementation When we want to implement behind code we need to register the same in GAC. |
Note: - Do not try to compile the project in VS.NET IDE. You can only compile the class assembly. The ASPX file you need to later paste it to the '_layout' directory i.e. 'C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\TEMPLATE\LAYOUTS'. |
Once you have copied the ASPX file and registered the behind code assembly in GAC, you can run and enjoy how it looks like.
If you are thinking that behind code pages implementation is lot of pain in SharePoint. Hang on as we move ahead you will see better way of implementation. Second we can not rule out the benefits as compared to the pain incurred in implementing behind code pages in ASP.NET.
What is the concept of features in SharePoint?
Whenever we think about SharePoint think in terms of collaboration. One of the much needed features in collaboration is on-demand functionality / feature activation. Feature makes it easier to activate and deactivate functionality in SharePoint.
Some points which you should note about features:-
. All features needs to be copied in "C:\Program Files\Common Files\Microsoft Shared\Web server extensions\12\Template\FEATURES\" directory. Microsoft Share reads the features from this directory. If you open the directory you can find pre-installed features by Share Point as shown below.
. Every feature will have two XML files one is the 'Feature.xml' and the other is 'ElementManifest.xml'.
. Share point understands there is a feature by reading the feature XML file from the features folder.
. All features are identified by a unique GUID number.
. Features emit events which can be captured to write custom code. These events are captured in assembly which needs to be registered in a GAC.
kya
. Summarizing what we discussed we have a 'feature.xml' which points to an assembly which captures the feature events for custom code. It also other XML file which defines what exactly this feature will do.
Can you explain the broader steps for deploying / activating a feature?
In order to understand the feature concepts lets deploy the simple application page i.e. 'SimplePageCodeBehind.aspx' as feature. So when the user activates this feature he will be able to browse the 'SimplePageCodeBehind.aspx'.
Step 1:- Let's create a project 'SharePointFeature'. You can find the source code of the same attached with this article. So below is the project tree which has the two XML files and a class file which will process the four events i.e. 'FeatureInstalled','FeaturesUnInstalling' , 'FeatureActivated' and 'FeatureDeactivating'.
Let's understand these three files first.
Feature.XML :- This is the most important file because it helps SharePoint identify the feature. All features in SharePoint are identified by the GUID key.
Title="Go to Custom Pages" Description="This features enables us to goto Custom Page" Scope="Web" Hidden="FALSE" ImageUrl="menuprofile.gif" ReceiverAssembly="SharePointFeature, Version=1.0.0.0, Culture=neutral, PublicKeyToken=af83741e324f585c" ReceiverClass="SharePointFeature.clsFeatureReceiver" xmlns="http://schemas.microsoft.com/sharepoint/" > |
To generate a new GUID click on Tools à Create GUID and click 'New GUID'. Tools menu you will get from within the IDE. We have marked the GUID value which you need to copy and paste in the 'feature.xml 'file.
Other than feature description and title there are two important things in the XML file. The first it points towards some other XML file and second it points to an assembly which captures events.
ElementManifest.XML file :- ElementManifest.xml file actually specifies how the implementation will look like. There are two important points to be noted for the ElementManiFest.XML file. The custom action tag specifies on which control the feature will be activated. The control we are targeting at this moment is the 'SiteActionsToolBar'. This tool bar is the one which you see on the right hand side corner of your SharePoint portal. There is also a URLaction property which specifies which URL it redirect to.
In other words 'ElementManifest.xml' specifies the location of the feature and which page it should redirect to.
FeatureReceiver.cs :- This class listens and implements custom actions of the feature.
We need to first refer the share point namespace as shown in the below code snippet.
using System; using System.Collections.Generic; using System.Text; // Refer the SharePoint namespace using Microsoft.SharePoint; |
We need to implement the 'SPFeatureReceiver' class and implement all the events.
namespace SharePointFeature { // Inherit from the 'SPFeatureReceiver" class public class clsFeatureReceiver : SPFeatureReceiver { // Implement the four events of SPFeatureReceiver class public override void FeatureInstalled(SPFeatureReceiverProperties properties){} public override void FeatureUninstalling(SPFeatureReceiverProperties properties) { } // This event fires when the feature is activated public override void FeatureActivated(SPFeatureReceiverProperties properties) { .... .... .... .... } // This event fires when the feature is deactivated public override void FeatureDeactivating(SPFeatureReceiverProperties properties) { .... .... .... ... } } } |
As a sample in the 'FeatureActivated' event we have set the description and title of the website.
public override void FeatureActivated(SPFeatureReceiverProperties properties) { // get the object of SharePoint Web SPWeb site = (SPWeb)properties.Feature.Parent; // Set the description ,properties , titile and update the SpWeb object site.Description = "Click on the SiteActions to See how the custom page display"; site.Properties["OriginalTitle"] = "Display CustomPage"; site.Properties.Update(); site.Title = "This Site now has the custom page display"; site.Update(); } |
In 'FeatureDeactivating' we have reverted back the title and description.
public override void FeatureDeactivating(SPFeatureReceiverProperties properties) { // Get hold of the SharePoint web object and reset back the values SPWeb site = (SPWeb)properties.Feature.Parent; site.Description = "Custom Page display is disabled"; site.Title = site.Properties["OriginalTitle"]; site.Update(); } |
Step 2 :- We need to register the compiled assembly in GAC and provide the token value in the 'Feature.XML' file. You need to use GACUTIL to register. You can get the token by browsing to 'c:\Windows\Assembly' and then viewing the properties of the assembly.
Step 3:- Copy the two XML file i.e. 'Feature.xml' and 'ElementManisfest.xml' in the 'C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\TEMPLATE\FEATURES\DisplayCustomPage' directory.
Step 4:- Now we need to install the feature using STSADM.exe. So go to dos prompt à and go to 'C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\BIN' directory.
>cd C:\Program Files\Common Files\Microsoft Shared\web server extensions\12\BIN |
To install the feature run the below command using 'STSADM'. Please note that you need to specify the relative directory path and not the physical path of 'Feature.xml' file.
>stsadm -o installfeature -filename DisplayCustomPage\Feature.xml |
To ensure that SharePoint registers about this feature run IISRESET on the machine.
Step 5:- Now click on the Site Action à Site Settings à Site Features and Activate the feature.
Now you can see your feature enabled in the site actions menu. If you click on the feature i.e 'Display Custom Pages' it will redirect you to 'SimplePageCodeBehind.aspx'.
The other point to be noted is that the events have fired and set the title and description as described in the code.
Try to experiment and deactivate the feature and you will see the title and description changing.
Note: - You can get the source for the feature in the ZIP file provided with the article |
I want that the feature should be only displayed to admin?
If you want only administrators to view the features set RequireSiteAdministrator="True" as shown in the below 'ElementManifest.XML' file.
Location="Microsoft.SharePoint.StandardMenu" Sequence="10" Title="Display Custom Pages" Description="This links helps to display Custom Page" ImageUrl="_layouts/SharePoint2/menuprofile.gif"> |
Source code
The source code has the following things:-
. Simple SharePoint behind code.
. Inline Share Point behind code
. SharePoint feature code
Download |
---|
questpond_1006_Source_Code.zip |
SharePoint Quick Start FAQ Part 1
SharePoint Quick Start FAQ Part 1
Introduction
What is SharePoint?
What is WSS and MOSS?
How does WSS actually work?
How does WSS work with IIS?
What is site and site collection?
What is the main advantage of using site collections?
What is the use of SQL Server in share point?
What is the concept of virtual path provider?
What is the concept of ghosting and unghosting in Share Point?
What is the concept of safemodeparser in ASP.NET?
What is the concept of Site pages and Application pages?
What Next?
Introduction
Hi Friends, below is quick start FAQ for people who are new to share point. We will warm up some theory in the first two articles and then do some practical on the same lines. I have made a 10 part series for share point and I hope you will enjoy it. This is the first part from the series. Get warmed with the theory first and then rest of SharePoint is a breeeeeze. This section covers sharepoint basics and the walks through how share point works with ASP.NET.
For past some days I have been writing and recording videos in design patterns, UML, FPA, Enterprise blocks and lot you can watch the videos at http://www.questpond.com/
You can download my 400 .NET FAQ E-Book from http://www.questpond.com/SampleDotNetInterviewQuestionBook.zip
What is SharePoint?
Share point helps team members to connect and exchange information in a collaborative manner. It helps to centralize enterprise information for efficient functioning. For instance below is how a normal organization works. Files and documents scattered in individual PC and data is transported according to custom protocols. The communication protocol for sending these data is also person dependent. Some body would use a email , some body would share a drive etc etc.
Share point unites all the documents in to one centralize place and unifies the data transport mechanism. In one words a central enterprise information portal.
What is WSS and MOSS?
Microsoft has divided share point products in two parts. One is called as WSS (Windows SharePoint services) and the other is MOSS (Microsoft Office SharePoint server). WSS is the platform on which MOSS is built. The WSS part is licensed through Windows 2003 server and it does not cost. MOSS is separate product by itself and it needs licensing and it has a good amount of cost J . WSS is good for small team and small projects. MOSS has extra functionalities in other words value added services. So the choice between WSS and MOSS will depend on budget of the project and the VAS provided by MOSS.
How does WSS actually work?
WSS does not work in an isolated fashion. It needs help of two more products IIS (Internet Information Server) and SQL Server.
How does WSS work with IIS?
In order to understand how WSS works with IIS we need first understand the concept of "HttpHandlers and HttpModules". If you are not aware of it you can refresh about the same at HTTPHandler.aspx .
Using the HttpHandlers and HttpModules request is first passed through the Share Point runtime and then passed to the ASP.NET runtime (aspnet_isapi.dll).
If you open the web.config file of a WSS enabled IIS web application you can see the application run time handlers and modules.
Eg:
...
...
We have highlighted the application runtime module.
...
...
What is site and site collection?
Share point is all about enterprise data. When we talk about enterprise data it looks some as shown in the figure below. In other words grouping and sub groupings of data.
SharePoint extends the IIS web application structure to accommodate the above defined data structure using site and site collections. We will see in the later section how to create site collections.
What is the main advantage of using site collections?
As said previously SharePoint is all about data and data should properly authenticated / authorized to proper users. By defining the structure in site and site collection we can now define roles and responsibilities according to data. For instance in the above figure we will assign all HR user to payroll, recruitment and assessment site. These users will not be assigned to account site collection. Same holds true for accounts user.
So when you design your hierarchy of site and site collection you need to keep in mind the enterprise hierarchy structure and design the same accordingly.
What is the use of SQL Server in share point?
SQL Server is used to store content and configuration information. We have two types of databases one is the content database and the other is the configuration database. We had said previously that content is according to every site. So every site has his own content database. For instance if we have a payroll site and recruitment site they have their own content database. Configuration database is for the entire site as they are used in web farms, site configuration and lot of other things which are generic and common across all the sites.
What is the concept of virtual path provider?
Any project has two parts one is the standard and common part and the other is the customized version. In ASP.NET we have two types of pages for any project one is common ASPX pages and the other is customized ASPX pages. Common pages are stored on file directories while customized versions of pages are stored in content database.
So in other words we need an abstract mechanism by which we can render pages from SQL Server content database and also from the virtual directories. This is achieved by using the virtual provider provided by SharePoint. So for all customized pages virtual provider reads from the content database and passes the same to the ASP.NET runtimes. For all common pages it goes to the directory, parses it and the passes the same across to the ASP.NET runtime.
Virtual provider is an abstraction which loads the page from the content or the file system depending on whether it's customized or common pages and passes the same to the ASP.NET runtime.
What is the concept of ghosting and unghosting in SharePoint?
In SharePoint most of the site pages derive from templates. The custom pages only store the difference between them. The template is loaded in memory and applied to the custom pages on fly. In other words the template is stored in a cache. This definitely brings in performance and flexibility. Flexibility is in terms that when we change the template page it's applied to all custom pages. These pages are loaded from the file system. So pages which are loaded from the file system are termed as ghosted pages.
If the page data is loaded from the content database it's termed as unghosted pages.
As a note let me clarify the concept of document and content table as we are already trying to understand the concept of ghosting and unghosting. As we know that SharePoint stores all pages in the database. Looking from a 50,000 feet it has two tables one is the document table which has the entry of page and the other is the content which has the source code of the ASPX page.
So when a page is requested it first checks in the document table and then goes to the content table to load the page. If it does not find data of the page it goes to the file directory to load the page. This loading is done by ASP.NET runtime himself. But if there is data present in the content table then it's loaded by the 'safe mode' parser.
What is the concept of safemodeparser in ASP.NET?
As said the previous section there are two tables one is the document and the other content. If the page is stored in the content database it's loaded by the SafeModeParser which is page parser provided by SharePoint. If there is no data found in the content it's loaded from the file directory by simple ASP.NET runtime.
What is the concept of Site pages and Application pages?
Site pages are customized pages and are saved in to content database. So when you use the SharePoint designer to make custom changes it saves the changes in to content database. If you want to make generic pages in a site collection which will be used by every one, like for instance the 'Settings.aspx' page then you need to use application pages.
In other words Site pages are nothing but customized pages stored in content, while application pages are generic pages which will be used by all the sites in a site collection.
6 basic steps of how to create a WebPart in SharePoint
Introduction
Step 1:- Create the Webpart
Step 2 :- Copy the compile DLL to the virtual directory in the BIN folder.
Step 3:- Make entry of the WebPart in to web.config file.
Step 4:- Add it to the WebPart gallery.
Step 5:- Add the WebPart to site pages.
Step 6:- View the WebPart.
Introduction
This is beginners tutorial of how to deploy a WebPart in SharePoint. It is a 6 step procedure and this tutorial will walk through the same.
Step 1:- Create the Webpart
The first step is to create the WebPart. Below is the code snippet of a webPart. So we need to reference the 'WebParts' , the custom webpart class should inherit from 'WebPart' class and finally we need to override the 'CreateChildControls' method with our custom implementation.
Step 2 :- Copy the compile DLL to the virtual directory in the BIN folder.
The second step is to copy the compiled DLL in the VIRTUAL DIRECTORY of the sharepoint site.
You can get the virtual directory from the IIS from home directory tab in IIS. For instance the current website is hosted on the sharepoint 80 virtual site which is actually located at 'C: \Inetpub\wwwroot\wss\VirtualDirectories\80'.
So now let's browse to 'C: \Inetpub\wwwroot\wss\VirtualDirectories\80\bin' directory and copy the DLL in the bin folder.
Step 3:- Make entry of the WebPart in to web.config file.
Now that we have copied the DLL to 'bin' folder , we need to make a 'SafeControl' entry in the 'Web.Config' file of the virtual directory.
So now let's browse to 'C:\Inetpub\wwwroot\wss\VirtualDirectories\80' , open the web.config file and add the class library name in the 'SafeControls' section of the web.config file. Below code snippet shows the same in a visual manner.
Step 4:- Add it to the WebPart gallery
Now that we have added the WebPart in the 'web.config' file its time to make it available in the web part gallery. So click on Site settings ? then click webparts ? Click new button, you should see the figure shown below.
You can also see the webpart which you recently added is seen the gallery. To make it available click the check box and click populate gallery.
You should now see your webpart ( for this context it is SimpleLabelWebPart) in the WebPart gallery.
Step 5:- Add the WebPart to site pages.
Ok so now that our WebPart is available in the gallery it's time to add this WebPart to a SharePoint page. So goto the page where you want to add this WebPart , click on the site action menu and click edit page as shown in the below figure.
On the page you should see a 'Add a webpart' button , click on it and it will populate with the existing web parts. Browse to your web part and click add.
Once done your webpart is now added to the site page. You can edit the default webpart properties by clicking on 'Modify Shared WebPart'. For simplicity sake we have changed the title.
Step 6 :- View the WebPart
You can see the changed title display when view the page normally. So with a few lines of coding you can see how we have achieved huge customization.